当我在将数组声明为:
时遇到分段错误时,我遇到了问题long long ways[max+1];
其中,
unsigned int max = findMax(l,T); // l is an unsigned int array and T is an int.
和findMax是类型的函数:
unsigned int findMax(unsigned int arr[],int size)
我该如何解决这个问题?
答案 0 :(得分:2)
可能的原因是数组对于堆栈来说太大了。
截至目前,典型的堆栈大小为1-16 Mb(在嵌入式系统中可能相当少)。如果long long
是8个字节,则意味着分配一个超过125000个元素的数组可能会有问题。而且你也希望为其他自动变量留出空间。
不应在堆栈上分配真正大的数组。
您可以尝试在堆中分配它:
long long *ways = calloc(max+1, sizeof *ways);
if (ways == NULL) {
// allocation failed!!
}
// Do stuff.
free(ways);