目录
我们在开始可以先看这样一个故事
有两个特别强大的国家在过去进行了36个月的战争,在这期间发生了件事情,就是吃鸡蛋的时候,原始的方法是打破鸡蛋较大的一端,可那时的皇帝的祖父由于小时侯吃鸡蛋,按这种方法把手指弄破了,因此他的父亲,就下令,命令所有的子民吃鸡蛋的时候,必须先打破鸡蛋较小的一端,违令者重罚。然后老百姓对此法令极为反感,期间发生了多次叛乱,其中一个皇帝因此送命,另一个丢了王位,产生叛乱的原因就是另一个国家Blefuscu的国王大臣煽动起来的,叛乱平息后,就逃到这个帝国避难。据估计,先后几次有11000余人情愿死也不肯去打破鸡蛋较小的端吃鸡蛋。这个其实讽刺当时英国和法国之间持续的冲突。Danny Cohen一位网络协议的开创者,第一次使用这两个术语指代字节顺序,后来就被大家广泛接受,这个就是关于大端小端名词的由来。
1.什么是大端和小端
大端模式:就是高位字节排放在内存的低地址端,低位字节排放在内存的高地址端。
(其实,大端模式才是我们直观上认为的模式,但实际并不是这样)
小端模式:就是低字节排放在内存的低地址端,高位字节排放在内存的高地址端。
也就是这样的
下面我们看个例子
我们在VS环境下,进行深入分析:
数据本来在内存中存储是由高地址到低地址的 ,但我们在VS中看它是由高字节序到低字节序存储的,也就是小端存储,所以我们可以认为VS是小端存储模式
2.为什么会有大小端模式的区分
这是因为在计算机系统中,我们是以字节为单位的,每个地址单元都对应着一个字节,一个字节为8bit。但是在C语言中除了8 bit的char之外,还有16 bit的short型,32 bit的long型(要看具体的编译器),另外,对于位数大于8位的处理器,例如16位或者32位的处理器,由于寄存器宽度大于一个字节,那么必然存在着一个如何将多个字节安排的问题。因此就导致了大端存储模式和小端存储模式。
3. 例题
百度在2015年系工程师笔试题中就让设计一个程序来判断当前机器的字长
先写主函数
int main()
{
int ret = check_sys();
if (ret == 1)
{
printf("小端\n");
}
else
{
printf("大端\n");
}
return 0;
}
如果check_sys()函数返回1,那就是小端存储,若返回0,就是大端存储
int check_sys()
{
int a = 1;
char* p = (char*)&a;
if (*p == 1)
{
return 1;//小端
}
else
{
return 0;//大端
}
}
我们也可以精简代码(不用if来判断,直接return 把*p 返回)
int check_sys()
{
int a = 1;
char* p = (char*)&a;
return *p;
}
还可以继续精简代码(不用创建临时变量p,直接return把&a返回 )
int check_sys()
{
int a = 1;
return *(char*)&a;
}
代码合起来就是
int check_sys()
{
int a = 1;
return *(char*)&a;
}
int main()
{
int ret = check_sys();
if (ret == 1)
{
printf("小端\n");
}
else
{
printf("大端\n");
}
return 0;
}
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。
文章由极客之音整理,本文链接:https://www.bmabk.com/index.php/post/87392.html