union utype
{
int i
char a
}
void main()
{
union utype u
u.i = 1
if (u.a)
printf("小端\n")
else
printf("大端\n")
}
如何确认系统是采用大端还是小端**
1、大小端
**大端(存储)模式:**是指一个数据的低位字节序的内容放在高地址处,高位字节序存的内容放在低地址处。
如:一个数0x12345678存放在一个4字节空间里
**小端(存储)模式:**是指一个数据的低位字节序内容存放在低地址处,高位字节序的内容存放在高地址处。(可以总结为“小小小”即低位、低地址、小端)
如:一个数0x12345678存放在一个4字节空间里
在计算机系统中,我们是以字节为单位存放数据的,每个地址单元都对应着一个字节,一个字节为8bit。但在C语言中存在不同的数据类型,占用的字节数也各不相同,那么就存在怎样存放多个字节的问题,因此就出现了大端存储模式和小端存储模式。
大小端是由CPU和 *** 作系统来决定的,在 *** 作系统中,x86和一般的OS(如windows,FreeBSD,Linux)使用的是小端模式,但比如Mac OS是大端模式。
知道为什么有模式的存在,下面需要了解下具有有什么应用场景:
1)不同端模式的处理器进行数据传递时必须要考虑端模式的不同
2)在网络上传输数据时,由于数据传输的两端对应不同的硬件平台,采用的存储字节顺序可能不一致。所以在TCP/IP协议规定了在网络上必须采用网络字节顺序,也就是大端模式。对于char型数据只占一个字节,无所谓大端和小端。而对于非char类型数据,必须在数据发送到网络上之前将其转换成大端模式。接收网络数据时按符合接受主机的环境接收。
2、如果知道当前系统是采用的什么模式:
1)
通过查看一个变量在内存中存放的位置来判断
int test1_endian() {
int i = 1
char *a = (char *)&i
if (*a == 1)
printf("小端\n")
else
printf("大端\n")
return 0
}
2、用联合体
int test2_endian() {
union {
int i
char c
}un
un.i = 1
if(un.c == 1) {
printf("小端")
}
else {
printf("大端")
}
return 0
}
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)