最近学习《深入理解计算机操作系统》这本书,留下点东西,一边做点笔记,一边与大家分享。
1.内存
我们所说的内存是虚拟内存,所有进程看到的内存地址都是一样的。
内存中大概什么位置存放什么内存,这个不提了,关于操作系统的书里基本都有。
这里主要讲一下一个变量在虚拟内存中是如何存储的。
内存地址:
内存可以理解为一个从上到下的一维数组,上面的地址大,下面的地址小。
存放一般是从编号小的地址,到编号大的地址存放。
比如,一个int的变量0x01234567,在不同的操作系统中存储如下,linux和windows都为小端,sun oracle为大端。
如果一个int型变量为0x1234那大小端存放应如下:
大端: 0x100 0x101 0x102 0x103
12 34
小端: 0x100. 0x101. 0x102 0x103
34 12
这个写代码很好验证。大端的机器少见,小端的机器到处都是。书里面有个习题,写个代码验一下就一目了然了。
题:思考下面对show_bytes的三次调用:
验证代码如下(show_bytes代码与书中的有一点差别,但是主流程没变)
#include <stdio.h>
typedef unsigned char *byte_pointer;
void show_bytes(byte_pointer pt, size_t len);
void show_bytes(byte_pointer pt, size_t len)
{
size_t i = 0;
for(; i<len; i++)
{
printf("%p:pt[%d]:%.2x. \n", &pt[i],i, pt[i]);
}
printf("##print over.\n");
}
int main()
{
int num = 0x87654321;
show_bytes((byte_pointer)&num, 1);
show_bytes((byte_pointer)&num, 2);
show_bytes((byte_pointer)&num, 3);
show_bytes((byte_pointer)&num, 4);
return 0;
}
运行结果如下:
0x7000042fb020:pt[0]:21.
##print over.
0x7000042fb020:pt[0]:21.
0x7000042fb021:pt[1]:43.
##print over.
0x7000042fb020:pt[0]:21.
0x7000042fb021:pt[1]:43.
0x7000042fb022:pt[2]:65.
##print over.
0x7000042fb020:pt[0]:21.
0x7000042fb021:pt[1]:43.
0x7000042fb022:pt[2]:65.
0x7000042fb023:pt[3]:87.
##print over.
Exited with status code: 0
这说明,小端机器的低字节存放较小的位。
如果这个int的数是0x654321,那么上面的运行结果中的pt[3]中没有值。
这书名,变量在内存中的存储是从低字节到高字节存储的。内存中变量开始存储时,先从变量自己内存的低字节开始占用。
如果需要占用高字节再占用,否则空着。