1,变量(比如定义一个整形int型的四个字节的变量int var)在内存中的存放的格式是大端的还是小端的?
比如定义一个变量int var = 1;如果CPU是32 位小端的cpu,编译器会把内存中某个地址连续的4个字节分别赋值为0x01,0x00,0x00,0x00, 那么cpu根据这个变量的地址,读取内存中的这连续的4个字节到自己的寄存器中,然后cpu的加法器把这4个字节的内容(当作数值1)进行加法运算。如果是大端cpu,编译器会赋值为0x00,0x00,0x00,0x01,然后cpu读取并用自己的加法器(当作数值1)运算。
同理,如果内存中的一个变量在地址0~3的内容分别是0x01, 0x00,0x00, 0x00,如果是小端的cpu,那么内存中的这4个字节的变量就表示数值1,因为这个值就被cpu的加法器当作1(低字节在低地址)来运算;如果是大端cpu,那么内存中的这4字节的变量就表示数值0x1 00 00 00,因为cpu的加法器把它当作值0x1 00 00 00(高字节在低地址)在来运算。
2,线程的栈是向低地址扩张还是高地址扩张?
C语言编译器会把 函数传参,中断,任务调度等编译为对应的栈操作PUSH var,cpu执行PUSH var指令,把var的内容放到SP寄存器的值所指的地址,同时SP寄存器的值自动加1或者减1(由cpu类型决定),如果cpu执行push命令时,SP寄存器的值是自增的,那么线程的栈是向高地址扩张的,如果是自减的,则线程的栈是向低地址扩张的。
原文地址:http://blog.csdn.net/ruanjianruanjianruan/article/details/44357721