zoukankan      html  css  js  c++  java
  • 实现判断机器大小端的两种方法

     

    大小端的更多内容参见:详解大端模式和小端模式

    第一种方法

    思路:利用指针的强制类型转换

    #include <stdio.h>
     
    int main(void)
    {
        int data1 = 0x12345678;
        int i;
     
        for(i=0; i<4; i++)
        {
            printf("%#x ----->%p\n",*((char *)&data1 + i),(char *)&data1 + i);
        }
     
        return 0;
    }

    image

    从输出的结果可以看出,高位地址0xbfc1b1ff存的是数据的高位0x12,低位地址0xbfc1b1fc存的是数据的低位0x78。所以是小端。同时我们亦可以看到,对数据data取地址实际指向的是存放低位数据的空间。

     

    第二种方法

     

    思路:利用共用体所有数据都从同一地址开始存储。

    #include <stdio.h>
     
    int main(void)
    {
        int i;
     
        union endian
        {
            int data;
            char ch;
        }test;
     
        test.data = 0x12345678;
        if(test.ch == 0x78)
        {
            printf("little endian!\n");
        }
        else
        {
            printf("big endian!\n");
        }
     
        for(i=0; i<4; i++)
        {
            printf("%#x ------- %p\n",*((char *)&test.data + i),(char *)&test.data + i); 
        }
        return 0;
    }

    image

  • 相关阅读:
    saltstack配置管理之YAML(二)
    自动化运维之saltstack 简单用法(一)
    异常处理,枚举,泛型
    面向对象二
    面向对象
    python面向对象
    方法(函数),内存空间,数组
    for循环,while循环,do while循环
    if判断,switch语句
    运算符
  • 原文地址:https://www.cnblogs.com/pengdonglin137/p/2941501.html
Copyright © 2011-2022 走看看