判断大端小端问题

#include <iostream>
using namespace std;

int checkCPU()
{
	union w
	{
		int a;
		char b;
	}c;
	c.a = 1;
	return (c.b == 1);
}

int main()
{
	int ret = checkCPU();
	return 0;
}

大端:高位存放在低地址,低位放在高地址

小端:高位存放在高地址,低位放在低地址


为什么用联合(union)?

因为在系统中联合保存数据从低地址开始保存,所以char类型拿到的是int类型的保存在低地址的值。

小端:

0x0001   0x0002   0x0003   0x0004   (地址)     int

  0x01       0x00         0x00      0x00       (数据)

  0x01                                                       (数据)    char

大端:

0x0001   0x0002   0x0003   0x0004   (地址)     int

  0x00       0x00         0x00      0x01       (数据)

  0x00                                                       (数据)    char



### 判断大端和小字节序的方法 在计算机系统中,字节序用于描述多字节数据(如整数)在内存中的存储顺序。大端字节序表示最高有效字节存储在最低地址,而小字节序则相反[^1]。以下是几种常见的判断方法: #### 方法一:使用联合体(Union) 通过联合体可以轻松判断系统的字节序。以下是一个示例代码: ```c #include <stdio.h> #include <stdint.h> union { uint32_t integer; uint8_t bytes[4]; } endian_test; int main() { endian_test.integer = 0x01020304; if (endian_test.bytes[0] == 0x01) { printf("Big-endian\n"); } else if (endian_test.bytes[0] == 0x04) { printf("Little-endian\n"); } return 0; } ``` 如果程序输出 `Big-endian`,则系统为大端字节序;如果输出 `Little-endian`,则系统为小字节序[^2]。 #### 方法二:直接赋值并检查低地址 可以通过直接将一个整数值赋给变量,并检查其低地址的值来判断字节序。例如: ```c #include <stdio.h> int main() { unsigned int number = 0x12345678; unsigned char *byte_pointer = (unsigned char *)&number; if (*byte_pointer == 0x78) { printf("Little-endian\n"); } else if (*byte_pointer == 0x12) { printf("Big-endian\n"); } return 0; } ``` 此方法同样适用于大多数编程语言,只需调整语法即可[^3]。 #### 方法三:使用标准库函数 在某些编程语言中,提供了内置函数或常量来判断字节序。例如,在Python中可以使用 `sys.byteorder`: ```python import sys if sys.byteorder == 'big': print("Big-endian") else: print("Little-endian") ``` 这种方法简单且易于实现,适合脚本语言用户[^4]。 ### 注意事项 - 字节序的概念主要应用于多字节数据类型,如整数、浮点数等。 - 网络协议通常采用大端字节序(网络字节序),因此在跨平台通信时需要特别注意字节序转换[^5]。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值