zoukankan      html  css  js  c++  java
  • 大端小端

    大端格式:在这种格式中,字数据的高字节存储在低地址中,而字数据的低字节则存放在高地址中, 小端格式:与大端存储格式相反,在小端存储格式中,低地址中存放的是字数据的低字节,高地址存放的是字数据的高字节

    这里写图片描述 
    接下来,如果别人给你出一道题,让你编写一个简单的程序就能测试出当前系统是大端存储还是小端存储,我们该怎么解决呢。

    在这里我们可以考虑用两种方法,一种是利用指针,还有一种巧妙的方法是利用union联合体;

     首先我们要知道union的几点特性:
    

    1、union中可以定义多个成员,union的大小由最大的成员的大小决定。 
    2、union成员共享同一块大小的内存,一次只能使用其中的一个成员。 
    3、对某一个成员赋值,会覆盖其他成员的值 
    来看一个简单的代码:

        union  UN
        {
           char c;
           int i;
        }un;
    

      

      其实此时系统为我们分配了一块int型大小的空间,对我们定义的字符c和整形i进行存储,的存储方式如下
    

    这里写图片描述 
    可以看到c和i是公用一块空间,所以在同一时刻我们并不能取到union中的几个内容,而是只能保证在某一时间使用一个变量成员。


    下面为测试当前系统是大端还是小端存储的两个小程序:

     
    方法一:  利用指针的特性

    #include<stdio.h> #include<windows.h> int check_sys() { int a = 1; char *p = (char *)&a; if (*p == 1) return 0; else return 1; } int main() { int ret = 0; ret = check_sys(); if (ret == 0) printf("little"); else printf("big"); system("pause"); return 0; } 方法二:利用共用体union int check_sys() { union UN { char c; int i; }un; un.i = 1; if (un.c == 1) return 0; else return 1; } int main() { int ret = 0; ret = check_sys(); if (ret == 0) printf("little"); else printf("big"); system("pause"); return 0; }

      

     
  • 相关阅读:
    列表页无限滚动翻页组件--解决性能问题
    UI组件化介绍
    js请求数据的例子
    移动端bug和优化
    利用字符串路径获取对象集合的值
    n个骰子的和,组成数字m的可能
    算法-回形路径
    学习python-跨平台获取键盘事件
    获取数组中多个相加等于0的一组数字 javascript
    一个矩阵 JavaScript
  • 原文地址:https://www.cnblogs.com/MrListening/p/5372366.html
Copyright © 2011-2022 走看看