C语言判断大小端

思路:

明确大小端:

(1)小端:底地址存数据的低位,高地址存数据的高位,用“小小小”概括(小端,小地址,小数据)

(2)大端:底地址存数据的高位,高地址存数据的低位

如图示:

C语言判断大小端_第1张图片

程序思路:

(1)思考数据的存储方式以及地址排列,int型 在32 位操作系统下 占有 4字节,

              char 型 占有1字符,因此可以利用char 型指针判断 int 型地址与数据

(2)如: 若有整形 int b=0x 77 ff 10 01,则我们知 0x 01 ,0x 10,0x ff ,0x 77分别各为一字节,

              因此用char 型指针的值 与 其 解应用 后的值 和b 做判断

头文件:

#pragma once
#include

void test()
{
    int tt =0x77ff1001;
    char *pp = (char*)&tt;
    //输出tt 的信息
    printf("\n\ttt:%#X\t &tt:%p \n", tt, &tt);
    //输出tt 的下一个字节起始位置
    printf("\n\ttt:%#X\t &tt:%p \n", tt, &tt+1);
    printf("检验:\n");
    // 输出tt 的第一字节的值 ,与地址
    printf("\tpp:%#X\t &pp:%p \n\n", *pp, pp);
    // 输出tt 的第二字节的值,与地址
    printf("\tpt:%#X\t &(pp1):%p \n\n", *(pp + 1), pp + 1);
    // 输出tt 的第三字节的值,与地址
    printf("\tpt:%#X\t &(pt2):%p \n\n", *(pp + 2), pp + 2);
    // 输出tt 的第四字节的值,与地址
    printf("\tpt:%#X\t &(pt3):%p \n\n", *(pp + 3), pp + 3);
    //输出tt 的下一个字节起始位置
    printf("\tpt:%#X\t &(p+t):%p \n\n", *(pp + 4), pp + 4);
}

 

源文件:

#include"is_big_small.h"
#include

int main()
{
    test();
    system("pause");
    return 0;
}

结果如下:(输出提示中有一点错误:pp为*pp,&pp为 pp    >^<)

C语言判断大小端_第2张图片

 

你可能感兴趣的:(成长)