请考虑以下代码:
#include <iostream>
using namespace std;
int main()
{
const int max=500008;
long long cordx[max],cordy[max];
char type[max];
int n;
cin>>n;
for(int m=0;m<n;m++)
cin>>type[m]>>cordx[m]>>cordy[m];
return 0;
}
此代码在运行时给出了分段错误错误。
但是当我改变我的代码时:
for(m=0;m<n;m++)
cin>>cordx[m];
它没有给我任何错误。
只有当我尝试这样输入时才会给我错误:
cin>>type[m]>>cordx[m]>>cordy[m];
答案 0 :(得分:3)
long long通常是8个字节。 cordx
和cordy
每个请求空间为500008个自动存储空间。那是大约8 MB的存储空间,可以远远超过或者提供最大的自动存储空间。典型的PC使用堆栈进行自动存储,堆栈的大小通常在1到10 MB之间。
解决方案是使用std::vector
从更大的动态存储中分配存储,或者定义要在静态存储中分配的变量(使它们static
或全局定义它们。)
此外,用户可以指定大于500008的n
并强制访问超出范围。