在PC上执行下面的程序:
int main()
{
int j = 0xaaaa ;
long long ll = 0x123456789abcdef ;
unsigned char* pc = (unsigned char*)&ll ;
printf("ll=0x%x, j=0x%x/n", ll, j) ;
printf("ll=%llx, j=%x/n", ll, j) ;
printf("&ll=%p, &j=%p, pc=%p/n", &ll, &j, pc) ;
printf("pc[0-8]=%02x %02x %02x %02x %02x %02x %02x %02x/n", pc[0], pc[1], pc[2], pc[3], pc[4], pc[5], pc[6], pc[7]);
return 0 ;
}
打印结果:
ll=0x89abcdef, j=0x1234567 //这里出现打印错误。j为0xaaaa,结果打印显示为0x1234567。%x一次打印4个字节,但是ll长为8个字节,所以前面的%x打印了靠近&ll地址的4个字节,后面的%x打印了远离&ll地址的4个字节。这也从另外一个角度说明了,PC上字节序是小端的。
ll=123456789abcdef, j=aaaa //llx就可以打印long long型了。
&ll=0xbff775b8, &j=0xbff775c4, pc=0xbff775b8 //可以看出,分配栈内存时,地址是向上增长的。
pc[0-8]=ef cd ab 89 67 45 23 01 //靠近小地址的是大值,是为小端。