大端 小端 C

所谓的大端模式,是指数据的低位保存在内存的高地址中,而数据的高位,保存在内存的低地址中;

所谓的小端模式,是指数据的低位保存在内存的低地址中,而数据的高位保存在内存的高地址中。

 

#include <iostream>

using namespace std;
union
{
int i;
char x[2];
}a;

int main()
{
       a.x[0] = 10;
       a.x[1] = 1;
       printf("%d\n",a.i); 
       printf("%xd\n",a.i);
       system("pause");
       return 0;
}  //dev_c++  运行结果 0X010a  所以是小端!

short int x;

char x0,x1;

x=0x1122;

x0=((char*)&x)[0];  //低地址单元
x1=((char*)&x)[1];  //高地址单元

若x0=0x11,则是大端; 若x0=0x22(数据的低位存在低地址中),则是小端......

 

 

再来个例子:

main()
{
union{ /*定义一个联合*/
int i;
struct{ /*在联合中定义一个结构*/
char first;
char second;
}half;
}number;
number.i=0x4241; /*联合成员赋值*/
printf("%c%c/n", number.half.first, mumber.half.second);
number.half.first='a'; /*联合中结构成员赋值*/
number.half.second='b';
printf("%x/n", number.i);
getch();
}
答案: AB (0x41对应'A',是低位;Ox42对应'B',是高位)

              6261   //a ,b的ask码

 

### 大端的定义 大端(Big-Endian)和小(Little-Endian)描述了多字节数据在内存中存储的字节顺序。大端模式下,高位字节排放在内存的低地址,低位字节排放在内存的高地址;小模式下,低位字节排放在内存的低地址,高位字节排放在内存的高地址。例如,对于十六进制数 0x12345678,在大端模式下内存排列为 0x12 0x34 0x56 0x78,在小模式下内存排列为 0x78 0x56 0x34 0x12 [^1][^4]。 ### 大端的起源 “endian”一词来源于十八世纪爱尔兰作家乔纳森·斯威夫特(Jonathan Swift)的小说《格列佛游记》(Gulliver’s Travels)。小说中,小人国为水煮蛋该从大的一(Big-End)剥开还是小的一(Little-End)剥开而争论,争论的双方分别被称为“大端派(Big-Endians)”和“小派(Little-Endians)” [^3]。 ### 判断大端的方法 可以使用共用体来判断系统的字节序。如下例子,共用体 `endian_test` 具有 `short`(2Byte)和长度为 2 的 `char` 数组(2Byte)这 2 个成员。在 `main` 函数中,将整数值 0x0102 赋值给 `value`,然后通过检查 `bytes` 数组的值来判断大端类型。 如果以 0x01、0x02 的方式存储,则为大端。如果以 0x02、0x01 的方式存储,则为小 [^2]。 ```c #include <stdio.h> union endian_test { short value; char bytes[sizeof(short)]; }; int main() { union endian_test test; test.value = 0x0102; if (test.bytes[0] == 0x01 && test.bytes[1] == 0x02) { printf("Big endian\n"); } else if (test.bytes[0] == 0x02 && test.bytes[1] == 0x01) { printf("Little endian\n"); } else { printf("Unknown endian\n"); } return 0; } ``` ### 大端在编程中的处理 在网络编程中,由于不同的系统可能采用不同的字节序,因此需要进行字节序的转换。例如在 Socket 编程中,对 `BitConverter.IsLittleEndian` 进行判断,如果不是小则将字节数组进行反转转化为小 [^5]。 ```csharp //点击发送按钮 public void Send() { string sendStr = InputFeld.text; //组装协议 byte[] bodyBytes = System.Text.Encoding.Default.GetBytes(sendStr); Int16 len = (Int16)bodyBytes.Length; byte[] lenBytes = BitConverter.GetBytes(len); //大小编码 if(! BitConverter.IsLittleEndian){ Debug.Log("[Send] Reverse lenBytes"); lenBytes.Reverse(); } //拼接字节 byte[] sendBytes = lenBytes.Concat(bodyBytes).ToArray(); socket.Send(sendBytes); } ``` ### 大端的应用场景 - **硬件层面**:不同的处理器架构可能采用不同的字节序,如 x86 架构采用小字节序,而 PowerPC 架构采用大端字节序。 - **网络通信**:网络协议通常规定使用大端字节序(也称为网络字节序),因此在进行网络数据传输时,需要将主机字节序转换为网络字节序,接收数据时再将网络字节序转换为主机字节序。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值