Hellow,我是jack,今天给大家分享的是C语言实现机器的字节序的判断。话不多说,让我们直接进入正题。
首先,让我们先介绍一下什么是字节序。
字节序,顾名思义,就是字节组织的顺序。我们可以将其根据其存储时从低位开始还是从高位开始分为两种,具体如下:
类型 | 简写 | 本质 |
---|---|---|
大端 | BE(big endian) | 将高序字节存储在起始地址 |
小端 | LE(little endian) | 将低序字节存储在起始地址 |
两种字节序优缺点
小端优点:符合人的思维的字节序地址低位存储值的低位地址高位存储值的高位。从人的第一观感来说低位值小,就应该放在内存地址小的地方,也即内存地址低位;反之,高位值就应该放在内存地址大的地方,也即内存地址高位。
大端优点:直观的字节序地址,不要考虑对应关系只需要把内存地址从左到右按照由低到高的顺序写出,把值按照通常的高位到低位的顺序写出两者对照,一个字节一个字节的填充进去。
知道了这些,接下来就让我们来学习当前我们的面前的机器是小端还是大端存储。
//写代码判断当前机器的字节序
int chick_sys()
{
int a = 1;
char* p = (char*)&a; //p相当于指向a中的地址的第一个占有位
/*接着简单的判断p的值就可以判断机器的存储模式了
if (p == 0) { return 1; }
else
{
return 0;