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

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

相关推荐
语戚26 分钟前
力扣 968. 监控二叉树 —— 贪心 & 树形 DP 双解法递归 + 非递归全解(Java 实现)
java·算法·leetcode·贪心算法·动态规划·力扣·
skywalker_1128 分钟前
力扣hot100-7(接雨水),8(无重复字符的最长子串)
算法·leetcode·职场和发展
wjs20241 小时前
JavaScript 语句
开发语言
bIo7lyA8v2 小时前
算法稳定性分析中的输入扰动建模的技术9
算法
CoderCodingNo2 小时前
【GESP】C++三级真题 luogu-B4499, [GESP202603 三级] 二进制回文串
数据结构·c++·算法
sinat_286945192 小时前
AI Coding 时代的 TDD:从理念到工程落地
人工智能·深度学习·算法·tdd
炽烈小老头2 小时前
【 每天学习一点算法 2026/04/12】x 的平方根
学习·算法
ASKED_20192 小时前
从排序到生成:腾讯广告算法大赛 2025 baseline解读
人工智能·算法
田梓燊2 小时前
leetcode 160
算法·leetcode·职场和发展