大小端是描述数据在存储时字节顺序的概念。它指示了在多字节数据类型在存储或传输时,字节的排列方式(假定地址是从低到高)是从高位到低位(大端字节序)还是从低位到高位(小端字节序)。
- 命令行方式
file /bin/bash
/*输出中的 "ELF 64-bit **LSB** executable, x86-64, version 1 (SYSV),
dynamically linked" 中的 "**LSB**" 表示 "Least Significant Byte",
或者 "MSB" 表示 "Most Significant Byte"。这里的 "**LSB**" 表示小端字节序,"**MSB**" 表示大端字节序。*/
lscpu
/* 输出中的 "Byte Order" 一栏会显示 "Little Endian" 或 "Big Endian"*/
- 代码方式
代码如下:
#include <stdio.h>
int main()
{
unsigned int num = 1;
char *p = (char *)#
if(1 == *p)
{
printf("小端字节序\n");
}else
{
printf("大端字节序\n");
}
}
原理是int型整数1在小(大)端系统存储布局如下,每一个地址存储一个字节,假定首地址为0x100,地址一般从低到高排列:
小端系统:
0x100: 01
0x101: 00
0x102: 00
0x103: 00
大端系统:
0x100: 00
0x101: 00
0x102: 00
0x103: 01
然后我们将num的地址强转为一个char(单字节)型指针,这个时候p就是地址0x100,接下来判断0x100指向的这个字节的值是多少就可以知道系统是大端存储还是小端存储了。