据我所知,堆栈不是PE段映射内存(即它没有映射到PE win32段)。
我的问题是:堆栈内存驻留在哪里?操作系统把它放在哪里?
操作系统是否会在进程启动时为堆栈分配一页内存,并在跳转到进程的代码之前将ESP寄存器值更改为该页?我有点困惑..。
发布于 2012-12-26 19:05:52
操作系统把它放在它能在虚拟地址空间中找到一些空闲空间的任何地方。它不是PE文件的一部分。
每个进程都有一个单独的虚拟地址空间。模块被加载到该地址空间中。堆是在该地址空间中创建的。堆栈也是如此。
对于非托管进程,操作系统为新线程保留整个堆栈分配,然后按需提交内存。托管.net进程具有不同的策略。它们在创建每个线程时提交并保留整个堆栈分配。
https://stackoverflow.com/questions/14039643
复制相似问题