据我所知,堆栈不是PE段映射内存(即它没有映射到PE win32段)。
我的问题是:堆栈内存在哪里?操作系统把它放在哪里了?
操作系统在启动进程时是否为堆栈分配了一页内存,并在跳转到进程代码之前将ESP寄存器值更改为该页面?我有点困惑..
答案 0 :(得分:2)
操作系统将它放在虚拟地址空间中可以找到一些空闲空间的任何位置。它不是PE文件的一部分。
每个进程都有一个虚拟地址空间。模块被加载到该地址空间中。堆在该地址空间中创建。堆栈也是如此。
对于非托管进程,操作系统为新线程保留整个堆栈分配,然后根据需要提交内存。托管的.net流程有不同的策略。它们在创建每个线程时提交并保留整个堆栈分配。