c++ - 为什么大型本地数组会使我的程序崩溃,而全局数组却不会?

标签 c++ c arrays

<分区>

具有大型全局数组的程序:

int ar[2000000];

int main()
{
}

具有大型本地数组的程序:

int main()
{
    int ar[2000000];
}

当我在主函数中声明一个大数组时,程序崩溃并显示“SIGSEGV(段错误)”。

但是,当我将其声明为全局时,一切正常。这是为什么?

最佳答案

全局声明数组会导致编译器在已编译二进制文件的数据部分中包含数组的空间。在这种情况下,您将二进制大小增加了 8 MB(每个 int 2000000 * 4 字节)。但是,这确实意味着内存始终可用,不需要在堆栈或堆上分配。

编辑:@Blue Moon 正确地指出,未初始化 数组很可能会分配到 bss 数据段中,实际上可能不会占用额外的磁盘空间。一个初始化数组将被静态分配。

当您在程序中声明一个如此大的数组时,您可能已经超出了程序的堆栈大小(具有讽刺意味的是导致了 stack overflow )。

动态分配大型数组的更好方法是使用指针并像这样在堆上分配内存:

using namespace std;
int main() {
  int *ar;
  ar = malloc(2000000 * sizeof(int));

  if (ar != null) {
    // Do something 
    free(ar);
  }

  return 0;
}

关于 Memory Layout of C Programs can be found here 的一个很好的教程.

关于c++ - 为什么大型本地数组会使我的程序崩溃,而全局数组却不会?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/50834446/

相关文章:

c++ - 什么情况下可以使用异常处理?

c - 在 C 中使用数组查找 GCD

c++ - boost PropertyTree : How to read json array into?

c++ - 模板交叉继承

c++ - 编译时在 cuda 内核中使用 __ldg 时出错

c++ - Linux 中的未知类型名称 uint64_t 和 uint16_t uint8_t

c++ - 即使满足并输入退出条件,仍然打印错误消息

c - 为什么这个 "if"语句没有在它应该触发的时候触发?

c - 字符串数组插入问题

Javascript 游戏碰撞检测