这个问题有几个部分 .
根据网上可用的大部分资源以及根据教科书的说法,堆和堆栈内存在相反的方向上增长 .
-
堆和堆栈实际上总是朝着彼此相反的方向增长,特别是当操作系统为堆内存分配额外的内存时?
-
考虑到最初在程序中,只发生堆分配并使用最小的堆栈内存 . 因此,Heap将覆盖为Stack和堆分配的几乎整个组合内存 . 之后,Stack开始增长 . 是否会抛出错误或者是否会为Stack分配新的内存位置以使其达到最大限制(最大限制=“ulimit -s”命令显示的限制)?如果可以分配新位置,那么它是否违反了堆栈地址始终按顺序分配的条件?
-
数据部分中存储的初始化和未初始化变量的内存使用是否有任何预定义限制?
1 回答
回答:
堆和堆栈是实现细节,而不是语言规范所要求的 . 他们成长的方向不一定是彼此相对的;他们无论如何都可以成长 .
如果堆和堆栈相互增长,则可能会发生覆盖 . 如果内存分配器检查空间不足或者您有一个检查运行时堆栈分配的实用程序,则只会收到超限通知 . 请记住,并非所有平台都是Linux或Windows PC;许多是受限制的嵌入式系统 .
是的,变量必须有某处内存 . OS可以将变量分页到外部设备 . 变量有可能不是变量而是硬件寄存器 . 同样,这是所有平台特定的 . 语言标准强加的规则是变量必须是可寻址的,静态或自动变量必须具有唯一的地址(单一定义规则,ODR) .