我得到了关于列地址、权限、偏移量、设备等的理论......但我还没有找到每个段与程序本身的关系,例如考虑下面的地图:
08048000-08049000 r-xp 00000000 08:01 132351 /home/myuser/myprogram
08049000-0804a000 r--p 00000000 08:01 132351 /home/myuser/myprogram
0804a000-0804b000 rw-p 00001000 08:01 132351 /home/myuser/myprogram
0804b000-0804e000 rw-p 00000000 00:00 0
b751f000-b7520000 rw-p 00000000 00:00 0
..... more mapping starting with libc mapping
对于程序:
int global_noini; /* non-array non-initialized */
int global_ini=666; /* non-array initialized */
int vec_global_noini[4000]; /* array non-initialized */
/* array_initialized */
int vec_global_ini[]={31, 28, 31, 30, 31, 30, 31, 31, 30, 31, 30, 31};
int main(int argc, char **argv) {
int local; /* non-array local variable */
int vec_local[2500]; /* array local variable */
/* This function prints the map above */
show_map();
return 0;
}
我需要知道的是哪些部分是哪些变量以及为什么。
到目前为止,我相信(如果我错了,请纠正我)代码本身位于第一段,因为它具有x权限(执行)。但是非初始化变量、初始化变量、全局变量和局部变量呢?它们属于哪个段,为什么?