1

据我所知,堆栈不是PE 部分映射内存(即它没有映射到PE win32 部分)。

我的问题是:堆栈内存驻留在哪里?操作系统把它放在哪里?

操作系统是否在进程启动时为堆栈分配一页内存,并在跳转到进程代码之前将 ESP 寄存器值更改为该页?我有点困惑。。

4

1 回答 1

2

操作系统将它放在任何可以在虚拟地址空间中找到空闲空间的地方。它不是 PE 文件的一部分。

每个进程都有一个虚拟地址空间。模块被加载到该地址空间中。堆是在该地址空间中创建的。堆栈也是如此。

对于非托管进程,操作系统为新线程保留整个堆栈分配,然后按需提交内存。托管 .net 进程有不同的策略。他们在创建每个线程时提交并保留整个堆栈分配。

于 2012-12-26T11:05:51.997 回答