捕获堆栈溢出的内容

What catches stack overflow?

本文关键字:栈溢出 堆栈      更新时间:2023-10-16

如果一个堆栈由于无限递归之类的原因而不断增长,那么是什么导致了这种情况并停止执行?我可以想象这个程序会(错误地)开始向堆中写入,就好像它是堆栈内存一样,并一直运行,直到堆损坏导致潜在的崩溃?

大多数运行时系统都会在堆栈和堆之间留下间隙。试图访问此间隙中的内存会触发一个异常,该异常被转换为堆栈溢出。

这个问题与常见操作系统(例如x86)的虚拟内存管理密切相关。这些操作系统使用一种称为"分页"的技术。它使用一个将物理内存(RAM的地址)映射到虚拟地址的表。每个任务都有自己的表,因此也有自己的虚拟地址范围。如果任务试图访问位于未映射到任何物理地址的虚拟地址处的存储器块,或者试图在映射到设置了只读标志的物理地址的虚地址处写入,则触发页面故障。这种情况发生在堆栈溢出的情况下。页面错误是操作系统可以捕获的异常。在大多数情况下,它将终止相应的任务(在现代操作系统中,当然可能会将异常传播到任务本身)。有关更多信息,请参阅osdev。