当我们遇到跨多字节的程序对象时,这时候就需要判定清楚两个问题,一个是对象的地址,另外一个是存储器的字节排列情况。
int x=0x1234567,位于地址0x100处:
字节的排列不同的机器有着大端和小端之分,在不同类型的机器之间通过网络传送二进制数据时,接收程序字里的字节可能会出现反序排列,这时,网络应用程序的代码必须得遵守一定的字节顺序规则。
下面是一段字节表示的示例:
#include <stdio.h>
typedef unsigned char *byte_pointer;
void show_bytes(byte_pointer start,int len){
int i;
for(i=0;i<len;i++)
printf("%.2x",start[i]);
printf("\n");
}
void show_int(int x){
show_bytes((byte_pointer)&x,sizeof(int));
}
void show_pointer(void *x){
show_bytes((byte_pointer)&x,sizeof(void *));
}
void test_show_bytes(int val){
int ival=val;
int *pval=&ival;
show_int(ival);
show_pointer(pval);
}
int main(){
//test_show_bytes(12345);
printf("\n");
test_show_bytes(0x00003039);
printf("\n");
test_show_bytes(0x87654321);
}
运行结果:
$ ./show-bytes
39300000
a43aecfeff7f0000
21436587
a43aecfeff7f0000
运行机器是在Linux 64上,最低有效字节值先输出,这说明是小端法机器。值得注意的是Linux 64不同于Linux 32的4字节地址,它是8字节地址,所以是8字节的输出。
这时候问题来了,为何不同的整型输入,得到的却是相同的指针地址。