- r - 以节省内存的方式增长 data.frame
- ruby-on-rails - ruby/ruby on rails 内存泄漏检测
- android - 无法解析导入android.support.v7.app
- UNIX 域套接字与共享内存(映射文件)
堆栈溢出是如何发生的,确保它不会发生的最佳方法是什么,或者防止它发生的方法是什么,尤其是在 Web 服务器上,但其他示例也会很有趣?
最佳答案
堆栈
在这种情况下,堆栈是在程序运行时放置数据的后进先出缓冲区。后进先出 (LIFO) 意味着您放入的最后一个东西总是您取出的第一个东西 - 如果您将 2 个项目压入堆栈,“A”然后是“B”,那么您弹出的第一个东西堆栈外将是“B”,接下来是“A”。
当您在代码中调用函数时,函数调用之后的下一条指令将存储在堆栈中,以及可能被函数调用覆盖的任何存储空间。您调用的函数可能会为它自己的局部变量使用更多堆栈。当它完成时,它释放它使用的局部变量堆栈空间,然后返回到前一个函数。
堆栈溢出
堆栈溢出是指您为堆栈使用的内存比程序应该使用的内存多。在嵌入式系统中,您的堆栈可能只有 256 个字节,如果每个函数占用 32 个字节,那么您只能进行 8 个深度的函数调用 - 函数 1 调用函数 2 调用函数 3 调用函数 4 .... 谁调用函数 8 调用了函数 9,但函数 9 覆盖了堆栈外的内存。这可能会覆盖内存、代码等。
许多程序员通过调用函数 A,然后调用函数 B,然后调用函数 C,然后调用函数 A 来犯这个错误。它可能在大部分时间都有效,但只有一次错误的输入会导致它永远进入那个循环直到计算机识别出堆栈过度膨胀。
递归函数也是造成这种情况的一个原因,但如果您以递归方式编写(即您的函数调用自身),那么您需要注意这一点并使用静态/全局变量来防止无限递归。
通常,您使用的操作系统和编程语言管理堆栈,它不在您的掌控之中。您应该查看您的调用图(一个树结构,从您的主程序中显示每个函数调用的内容)以了解您的函数调用的深度,并检测非预期的循环和递归。故意循环和递归需要人为检查,如果它们相互调用太多次就会出错。
除了良好的编程实践、静态和动态测试之外,在这些高级系统上您无能为力。
嵌入式系统
在嵌入式世界中,尤其是在高可靠性代码(汽车、飞机、航天)中,您需要进行大量的代码审查和检查,但您还需要执行以下操作:
关于memory - "stack overflow"是如何发生的,如何预防?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/26158/
在编写代码时,当我编写 struct *Stack stack 时,代码无法工作,而当我像 struct Stack* stack 那样编写代码时,代码可以工作有人告诉我这两个代码之间的区别吗? 最佳
我的教授要我绘制堆栈吗?他想让我付诸行动吗?我觉得自己很愚蠢,但这不像任何人告诉我的那样!感谢您的帮助。 哇,你们真快。已经谢谢你了。完整的问题是:考虑两个堆栈,每个堆栈的大小为 n(即,每个堆栈最多
是new Stack[N]相当于new Stack[N]对于通用数据类型 Stack ? 编辑:虽然我知道最好避免混合泛型类型和数组,并且存在更强大的解决方案,但我的查询仍然存在:被广泛认可的教科书,
我正在尝试使用堆栈的 printf() 打印 stack.top() 的返回值,但它给出的格式不匹配。代码如下: int main(){ stack cards; char *ch1
我正在尝试做一个 dapp 项目。 我有一个堆栈太深的错误,但我不知道如何解决这个问题。 CompilerError: Stack too deep, try removing local varia
在哪里stack haddock (或 stack build --haddock )放置它生成的文档? 最佳答案 这取决于为“属于”生成黑线鳕的包的位置。 “本地”包的 Haddocks 是堆栈项目
按照目前的情况,这个问题不适合我们的问答形式。我们希望答案得到事实、引用或专业知识的支持,但这个问题可能会引发辩论、争论、投票或扩展讨论。如果您觉得这个问题可以改进并可能重新打开,visit the
基本上,我有 2 个文件(.adb 和 .ads)。我对 Ada 以及如何编译 2 个文件完全陌生。该程序是一个基本的堆栈实现。编译 .adb 文件时出现此编译错误。 $ gcc -c test_ad
关闭。这个问题需要更多focused .它目前不接受答案。 想改善这个问题吗?更新问题,使其仅关注一个问题 editing this post . 5年前关闭。 Improve this questi
您好,我正在尝试在微服务架构中使用 ELK 堆栈,其中有许多服务分布在许多服务器上。 现在我已经配置了 Kibana 和 ElasticSearch。现在我的疑问是我必须在哪里安装 Logstash。
很难说出这里要问什么。这个问题模棱两可、含糊不清、不完整、过于宽泛或夸夸其谈,无法以目前的形式得到合理的回答。如需帮助澄清此问题以便重新打开,visit the help center . 关闭 9
我正在学习 Haskell,但遇到了我没想到的异常“堆栈溢出”。 代码相当简单: type Reals = Double prod :: Reals -> Reals -> Reals prod a
在我的 PC(最新的 JDK 和编译器版本)上,我的程序运行得非常顺利。但在我教授的计算机上,她说她遇到了两个错误 1) Stack myStack= new Stack() 类型的非法开始 2) 非
当我尝试在调用跟踪后执行 ./stack.sh 时,我收到以下错误: `[Call Trace] ./stack.sh:217:source /home/work/devstack/stackrc
1 上下文 我参与了一个涉及大量 C 位和 FFI 的 Haskell 项目。所以我发现自己经常运行和重新运行命令,比如 $ stack build $ stack build --force-dir
关于 SO 上的堆栈的问题,终于!我的一生都让我走到了这一步。 所以我需要将我制作的一些相当大的自定义数据结构合并到一个堆栈中。我决定编写一个仅包含一个整数值的最小堆栈结构。这里是 - MODULE
我只是想知道为什么在括号之间嵌入表达式时会得到两个不同的成员列表,例如gl-stack。看起来,如果没有括号,表达式就会被完全求值,并且结果会立即传递到下一个管道组件。但通过括号,集合中的单个对象将被
是否可以保存Stack>在onSaveInstanceState . 是否可以通过另一种方式保存某些特定数据来管理 Activity 状态? 最佳答案 您无法将 View 保存到 bundle 中。无
这个问题已经有答案了: Why don't Java Generics support primitive types? (5 个回答) 已关闭 9 年前。 为什么我不能使用Stack ? 除了拳击之
基于数组的实现级别 #include "stack.h" void creat_stack(Stack *s) { s->Top = 0; } int isFull(Stack s) {
我是一名优秀的程序员,十分优秀!