【c语言】判断计算机的字节序是大端还是小端

一,代码

#include <stdio.h>

// 判断字节序是大端还是小端

int main(int argc, char *argv[])

{

unsigned int num = 0x01020304;

unsigned char *p = (unsigned char *)&num;

if (*p == 0x01)

{

printf("该计算机是大端格式\n");

}

if (*p == 0x04)

{

printf("该计算机是小端格式\n");

}

return 0;

}

二,详细解读

这段代码是一个简单的程序,用于检测计算机的字节序(Big Endian 或 Little Endian):

  1. `unsigned int num = 0x01020304;`:定义一个无符号整型变量 `num`,并将其赋值为十六进制数 `0x01020304`,这个值占四个字节。

  2. `unsigned char *p = (unsigned char *)&num;`:定义一个无符号字符型指针 `p`,并将 `num` 的地址强制转换为无符号字符型指针,这样 `p` 指向 `num` 的起始地址,且可以通过 `p` 访问 `num` 的每个字节。

  3. `if (*p == 0x01)`:通过判断指针 `p` 所指向的内容是否等于十六进制数 `0x01`,来检查计算机的字节序。如果 `*p` 等于 `0x01`,说明存储在 `num` 中的最低有效字节是 `0x01`,这表明计算机是大端格式。

  4. `if (*p == 0x04)`:如果 `*p` 等于 `0x04`,则说明最低有效字节是 `0x04`,这表明计算机是小端格式。

  5. 根据上述两个条件判断,程序会输出相应的信息来指示计算机的字节序。如果第一个条件成立,则输出 `"该计算机是大端格式"`;如果第二个条件成立,则输出 `"该计算机是小端格式"`。

总结:这段代码利用了指针的特性,通过访问多字节数据的最低有效字节来判断计算机的字节序。如果最低有效字节存储的值符合预期,则可以判断计算机的字节序。这是一种简单但不太可靠的方法,因为它依赖于特定数据的存储方式,而实际上计算机的字节序可能会受到编译器、操作系统等因素的影响。在实际开发中,通常会使用更加可靠和跨平台的方法来确定计算机的字节序。

相关推荐
Тиё Сиротака9 分钟前
红包分配算法的严格数学理论与完整实现
算法
故事不长丨1 小时前
C#定时器与延时操作的使用
开发语言·c#·.net·线程·定时器·winform
hefaxiang1 小时前
C语言常见概念(下)
c语言·开发语言
potato_may1 小时前
链式二叉树 —— 用指针构建的树形世界
c语言·数据结构·算法·链表·二叉树
欧阳天风1 小时前
js实现鼠标横向滚动
开发语言·前端·javascript
java修仙传1 小时前
每日一题,力扣560. 和为 K 的子数组
算法·leetcode
yue0082 小时前
C# Directory的用法介绍
开发语言·c#
ada7_2 小时前
LeetCode(python)——148.排序链表
python·算法·leetcode·链表
雨落秋垣2 小时前
手搓 Java 的用户行为跟踪系统
java·开发语言·linq
点云SLAM2 小时前
点云配准算法之-Voxelized GICP(VGICP)算法
算法·机器人·gpu·slam·点云配准·vgicp算法·gicp算法