大小端模式

大小端模式,第1张

加3g实验室的艰难之旅,遇到一道这样的实验室面试题:

输出结果为2000000

原题对a强制转换为int,64位机指针长度为八个字节,所以改为long int。

先来分析一下表达式,a为数组a[0]的地址,强制转换为长整型变为地址的数值后加一,实际为第一个元素的第二字节地址的数值。后转换为一指向整型的指针并赋值给ptr2。整型为4个字节,从第一元素第二字节开始往后读取四个字节,间接访问得出此四个字节代表的数值,并以十六进制输出。

那么问题来了,为什么是2000000,数组的整型元素在内存中是怎么储存的?这四个字节内存的是怎样的二进制数?为什么会这样储存?

经过度娘的帮助,它终于出现了—— 大小端模式

大端模式

大端模式是指数据的高位,保存在内存的低地址中,而数据的低位,保存在内存的高地址中。大端模式与我们的阅读习惯相同。

小端模式

小端模式是指数据的高位保存在内存的高地址中,而数据的低位保存在内存的低地址中。

举例

int a=2;

地址:小----->大

在大端模式中,a存为:

0x00 0x00 0x00 0x02

在小端模式中,a存为:

0x02 0x00 0x00 0x00

在计算机系统中,地址是以字节为单位的,每个地址单元都对应着一个字节,一个字节为8bit。但是在C语言中除了一个字节(8bit)的char之外,还有两个字节(16bit)的short型等超过一个字节的数据类型。另外,对于位数大于 8位的处理器,由于寄存器宽度大于一个字节。所以必然存在如何将多个字节安排的问题,因此就有了大端存储模式和小端存储模式。

小说《格列夫游记》中,小人国内部分裂成Big-endian和Little-endian两派,区别在于一派要求从鸡蛋的大头把鸡蛋打破,另一派要求从鸡蛋的小头把鸡蛋打破。斯威夫特借以讽刺英国的政党之争,在计算机工业中指数据储存顺序的分歧。

一个简单的判断数据储存模式为大端模式还是小端模式。

a[5] = {1,2,3,4,5};

第一个元素和第二个元素储存方式

(地址:小--->大)

大端模式下:

0x00 0x00 0x00 0x01 0x00 0x00 0x00 0x02

小端模式下:

0x01 0x00 0x00 0x00 0x02 0x00 0x00 0x00

截取第二个字节到第五个字节

大端模式:

0x00 0x00 0x01 0x00

小端模式:

0x00 0x00 0x00 0x02

读取数据

大端模式:

从高地址往低地址读取

0x00 0x00 0x01 0x00

读取数据转换为十六进制为100

小端模式:

从低地址往高地址读取

0x00 0x00 0x00 0x02

排成大端(0x02 0x00 0x00 0x00)

读取数据转换为十六进制为2000000

所以在大端模式下,结果为100。

在小端模式下,结果为2000000。

学C学得好迷啊,心好累,哈哈哈哈哈。

用选择排序法编写c语言,实现从键盘上输入10个数,按从大到小的顺序排序输出。代码如下:

#include<stdioh>

int main()

{

int i,j,a[10],t;

printf("输入数");

for (i = 0; i < 10; i++)

scanf("%d",&a[i]);

for (i = 0; i < 10; i++)

{

for (j = i + 1; j < 10;j++)

if (a[i] < a[j]){

t = a[i];

a[i] = a[j];

a[j] = t;

}

}

printf("从大到小");

for (i = 0; i < 10; i++)

printf("%2d", a[i]);

return 0;

}

扩展资料:

代码还可以设计,如下:

#include<stdioh>

int main()

{

int a[10],i,j,t;//定义数组;

for(i=0;i<10;i++){

scanf("%d",&a[i]);//给数组赋值;

}

for(i=0;i<9;i++)//10个数,进行9轮比较;

for(j=0;j<10-i;j++){//第一个数比较9次,依次递减;

if(a[j]>a[j+1]) {//交换值;

t=a[j];

a[j]=a[j+1];

a[j+1]=t;

}

}

for(i=0;i<10;i++){

printf("%d\n",a[i]);//输出数组的值;

}

return 0;

}

}

printf("the sorted numbers:\n");

for(i=0;i<10;i++)

printf(" %d",a[i]);

printf("\n");

}

参考资料:

百度百科-printf

字节顺序 ,又称 端序 尾序 (英语: Endianness )。在计算机科学计算机科学")领域中,是跨越多字节的程序对象的存储规则。

在几乎所有的机器上,多字节对象都被存储为连续的字节序列。例如在C语言中,一个类型为 int 的变量 x 地址为 0x100 ,那么其对应地址表达式 &x 的值为 0x100 。且 x 的四个字节将被存储在存储器的 0x100, 0x101, 0x102, 0x103 位置。

在计算机中一般讲字节序分为两类: Big-Endian (大端字节序) 和 Little-Endian 。

a) Little-Endian 高位字节在前,低位字节在后。

b) Big-Endian 低位字节在前,高位字节在后。

c) 网络字节序:TCP/IP各层协议将字节序定义为Big-Endian,因此TCP/IP协议中使用的字节序通常称之为网络字节序。

举个小例子:

整数127(十进制)在计算机(64位)中大/小端字节序

在x86的计算机中,一般采用的是小端字节序

输出

以上就是关于大小端模式全部的内容,包括:大小端模式、如何用c语言编写一个程序,实现按从大到小的顺序排序输出10个数、详解大端模式和小端模式等相关内容解答,如果想了解更多相关内容,可以关注我们,你们的支持是我们更新的动力!

欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/zz/9446752.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-04-28
下一篇 2023-04-28

发表评论

登录后才能评论

评论列表(0条)

保存