如何快速知道linux系统的大小端(windows系统一般为小端系统)

本文介绍了大小端字节序的概念,通过命令行工具如`file`和`lscpu`以及C语言代码示例,展示了如何检测系统是小端(LittleEndian)还是大端(BigEndian)字节序。内存布局的不同影响了多字节数据类型的存储方式。
摘要由CSDN通过智能技术生成

大小端是描述数据在存储时字节顺序的概念。它指示了在多字节数据类型在存储或传输时,字节的排列方式(假定地址是从低到高)是从高位到低位(大端字节序)还是从低位到高位(小端字节序)。

  1. 命令行方式
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"*/
  1. 代码方式
代码如下:
#include <stdio.h>

int main()
{
	unsigned int num = 1;
	char *p = (char *)&num;
	
	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指向的这个字节的值是多少就可以知道系统是大端存储还是小端存储了。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值