最大堆栈大小,ulimit -s,segfault 11 – 这是如何工作的?

最大堆栈大小,ulimit -s,segfault 11 – 这是如何工作的?,第1张

概述所以,我做: $ulimit -s8192 大.据了解,任何进程的堆栈段不能超过8192千字节. 现在来挑战那个.. #include <stdio.h>void over_8k(void) { char buf[1024*1024*20];}int main(int argc, char** argv) { printf("Starting .. "); ov 所以,我做:
$ulimit -s8192

大.据了解,任何进程的堆栈段不能超过8192千字节.

现在来挑战那个..

#include <stdio.h>voID over_8k(voID) {    char buf[1024*1024*20];}int main(int argc,char** argv) {    printf("Starting .. ");    over_8k();    printf(" finishing.\nHow dID this work?\n");    return 0;}

编译.然.没问题.那是不对的?超过8k单独应该有一个堆栈框架,好超过20兆字节.那么让我们尝试访问这些2000万个字节:

#include <stdio.h>#include <string.h>voID over_8k(voID) {    char buf[1024*1024*20];    memset(buf,'A',sizeof(buf));}int main(int argc,char** argv) {    printf("Starting .. ");    over_8k();    printf(" finishing.\nHow dID this work?\n");    return 0;}

.. 击鼓 ..

Segmentation fault: 11

大.但这不是我期望的错误吗?内存访问无效?

为什么会提高一个segfault,并且不会早于错误?打电话到超过8k吗?这个怎么用?我想知道一切

解决方法 扩大我的评论…

有两种可能性我可以想到:

编译器正在优化整个buf数组:

在MSVC中,启用优化后,整个阵列被完全优化,完全不分配.所以没有使用任何堆栈.

堆栈分配只是堆栈指针的递增/递减:

sub rsp,20971520

不会破产.这只是一个指针.当您尝试访问未映射内存时,它将只会发生故障.

总结

以上是内存溢出为你收集整理的最大堆栈大小,ulimit -s,segfault 11 – 这是如何工作的?全部内容,希望文章能够帮你解决最大堆栈大小,ulimit -s,segfault 11 – 这是如何工作的?所遇到的程序开发问题。

如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。

欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/yw/1048782.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2022-05-25
下一篇 2022-05-25

发表评论

登录后才能评论

评论列表(0条)

保存