最大堆栈大小,ulimit -s,segfault 11 C 这是如何工作的?
发布时间:2023-12-13 16:03:36 所属栏目:Linux 来源:DaWei
导读: 所以,我做:
$ulimit -s
8192
大.据了解,任何进程的堆栈段不能超过8192千字节.
现在来挑战那个..
#include <stdio.h>
void over_8k(void) {
char buf[1024*1024*20];
$ulimit -s
8192
大.据了解,任何进程的堆栈段不能超过8192千字节.
现在来挑战那个..
#include <stdio.h>
void over_8k(void) {
char buf[1024*1024*20];
所以,我做: $ulimit -s 8192 大.据了解,任何进程的堆栈段不能超过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不会破产.这只是一个指针.当您尝试访问未映射内存时,它将只会发生故障. (编辑:哈尔滨站长网) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |
相关内容
- 使用标准的linux工具链查找/替换htmlentities?
- 是否可以让cmake构建文件(CMakeLists.txt)不在CLion的root中
- Linux删除行中字符后的空格
- linux – 如何检查iptables中每条规则的命中数?
- linux-kernel – IO-APIC级别与PCI-MSI-X之间的差异
- dma_mmap_coherent和remap_pfn_range有什么区别?
- linux – 在bash脚本中使用iperf3获取时间戳
- 防止linux线程被调度程序中断
- linux – 从磁盘读取单个扇区
- linux – 为什么glibc二进制文件名为libc.so.6而不是libc.s
推荐文章
站长推荐