我们都知道一个进程跑起来后,其代码段、数据段、堆、栈等都分布在虚拟地址空间的不同位置。一个大致的内存映射图(ARM/MIPS架构均是如此)如下:
首先需要说明的是,这里说的都是虚拟地址空间,即对于32位系统来说的0~4G的空间;另外,进程中每个线程的栈、特有变量都是各自独有的,而代码段、只读数据、动态库代码段、堆都是所有线程共享的。
我们可以通过/proc下面的maps文件查看到一个进程的主线程的虚拟地址各区域的分布情况。
root@robdev:~# cat /proc/12443/maps
00008000-00009000 r-xp 00000000 1f:07 40 /root/procmap
00010000-00011000 rw-p 00000000 1f:07 40 /root/procmap
01c55000-01c56000 rw-p 00000000 00:00 0 [heap]
40018000-40019000 rw-p 00000000 00: