1

我得到了关于列地址、权限、偏移量、设备等的理论......但我还没有找到每个段与程序本身的关系,例如考虑下面的地图:

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权限(执行)。但是非初始化变量、初始化变量、全局变量和局部变量呢?它们属于哪个段,为什么?

4

1 回答 1

2

局部变量无处可寻。然而。当函数框架变为活动状态时,它们将在堆栈上。

常量数据肯定在某处标记为“r”,但不是“w”或“x”。

初始化的数据被标记为“rw”而不是“x”。未初始化的数据可能也有:其实.data(已初始化)和.bss(未初始化)是一样的,只是.bss不占用可执行映像中的空间(它被加载程序初始化为零) )。

于 2014-07-08T03:49:14.817 回答