高地址和低地址、高字节与低字节、大小端模式的转换、存储顺序
·
以下内容源于网络资源的学习与整理,如有侵权请告知删除。
一、高地址和低地址
二、高字节低字节
如int a=16777220,化为十六进制是0x01 00 00 04,则04属于低字节,01属于高字节。
三、大小端模式
(1)如果a在内存中的存放顺序为下图(即低字节存放在高地址),则为大端模式
(2)如果a在内存中的存放顺序为下图(即低字节存放在低地址),则为小端模式
(3)如何互换(通过移位操作再或)
四、存放顺序
数据在内存中存放的原则
(1)一个整数类型内部
低地址存储低位,高地址存储高位。比如int a=1,则存储情况为0000(高地址) 0000 0000 0001(低地址)。
(2)若干个局部变量(在栈中存储的)
先定义的高地址,后定义的低地址。
(3)类、结构体或数组的元素
先定义的低地址,后定义的高地址。
五、测试说明
(1)整数类型内部:低地址存储低位,高地址存储高位。
#include<iostream> using namespace std; union U { char str[2]; short int num; }; int main() { U u; u.str[0] = 10;//存放在低地址,0000 1010 u.str[1] = 1;//存放在高地址, 0000 0001 cout << u.num << endl;//组合的时候,整数类型内部低地址存储低位,高地址存储高位,因此是0000 0001 0000 1010 = 266 system("PAUSE"); return 0; }
(2)若干个局部变量(在栈中存储的):先定义的高地址,后定义的低地址。
类、结构体、数组中的元素:先定义的低地址,后定义的高地址
class Test { public: int m; int n; }; int main() { int a; char b; int c[10]; Test t; cout << (size_t)&a << endl;//结果1 cout << (size_t)&b << endl;//结果2 cout << (size_t)&c << endl;//结果3 cout << (size_t)&t << endl;//结果4 cout << (size_t)&t.m << endl;//结果5 cout << (size_t)&t.n << endl;//结果6 system("PAUSE"); return 0; }
结果1>结果2>结果3>结果4=结果5<结果6
分析:
结果1>结果2>结果3>结果4,是因为a、b、c、t都是局部变量,在栈上存储,栈是从高地址到低地址,因此地址逐渐减小。
结果5<结果6,是因为结构体内部,先定义的地址小,后定义的地址大,这与类内的成员,数组总的元素,都是类似的。
分析它们的数值差,可以发现字节对齐问题,数组名占用4字节等问题。
总的来说,具体的地址,需要考虑“栈的高地址到低地址”、“字节对齐”、“数组”这样的特殊情况等等。
更多推荐
已为社区贡献7条内容
所有评论(0)