Find centralized, trusted content and collaborate around the technologies you use most.
Teams
Q&A for work
Connect and share knowledge within a single location that is structured and easy to search.
据我所知,堆栈不是PE 部分映射内存(即它没有映射到PE win32 部分)。
我的问题是:堆栈内存驻留在哪里?操作系统把它放在哪里?
操作系统是否在进程启动时为堆栈分配一页内存,并在跳转到进程代码之前将 ESP 寄存器值更改为该页?我有点困惑。。
操作系统将它放在任何可以在虚拟地址空间中找到空闲空间的地方。它不是 PE 文件的一部分。
每个进程都有一个虚拟地址空间。模块被加载到该地址空间中。堆是在该地址空间中创建的。堆栈也是如此。
对于非托管进程,操作系统为新线程保留整个堆栈分配,然后按需提交内存。托管 .net 进程有不同的策略。他们在创建每个线程时提交并保留整个堆栈分配。