寻址和字节顺序

当我们遇到跨多字节的程序对象时,这时候就需要判定清楚两个问题,一个是对象的地址,另外一个是存储器的字节排列情况。

int x=0x1234567,位于地址0x100处:

寻址和字节顺序_第1张图片

字节的排列不同的机器有着大端和小端之分,在不同类型的机器之间通过网络传送二进制数据时,接收程序字里的字节可能会出现反序排列,这时,网络应用程序的代码必须得遵守一定的字节顺序规则。

下面是一段字节表示的示例:

#include 

typedef unsigned char *byte_pointer;

void show_bytes(byte_pointer start,int len){

              int i;
              for(i=0;i

运行结果:

$ ./show-bytes

39300000
a43aecfeff7f0000

21436587
a43aecfeff7f0000

运行机器是在Linux 64上,最低有效字节值先输出,这说明是小端法机器。值得注意的是Linux 64不同于Linux 32的4字节地址,它是8字节地址,所以是8字节的输出。

这时候问题来了,为何不同的整型输入,得到的却是相同的指针地址。

你可能感兴趣的:(寻址和字节顺序)