为什么这个unsigned int会出现段错误

Why am I getting segfault from this unsigned int?

本文关键字:段错误 错误 unsigned int 为什么      更新时间:2023-10-16

我试图初始化一个整数数组并将所有元素设置为1。我需要数组的上界为4294967295,或者32位unsigned int的最大可能数。

这对我来说似乎是一个微不足道的任务,它应该是,但我遇到了segfault。我可以运行空的for循环,它似乎工作得很好(虽然很慢,但它处理了近43亿个数字,所以我不会抱怨)。当我试图在循环内执行任何类型的操作时,问题似乎出现了。我下面的指令- primeArray[i] = 1; -导致segfault错误。据我所知,这应该不会导致数组溢出。如果我注释掉那行,没有segfault

很晚了,我疲惫的眼睛可能只是错过了一些简单的东西,但我可以再用一副。

这是我得到的:

#include <stdio.h>
#include <unistd.h>
#include <sys/types.h>
#include <stdlib.h>
#include <errno.h>
#include <string.h>
#include <stdint.h>
#define LIMIT 0xFFFFFFFF;
int main(int argc, char const *argv[])
{
    uint32_t i;
    uint32_t numberOfPrimes = LIMIT;        // hardcoded for debugging
    int *primeArray = (int*) malloc(numberOfPrimes * sizeof(int));
    for (i = 0; i < numberOfPrimes; ++i) {
        primeArray[i] = 1;
    }
}

检查来自malloc()的返回代码,以确保实际分配了数组。我怀疑下面的测试会失败:

int *primeArray = (int*) malloc(numberOfPrimes * sizeof(int));
if (primeArray != NULL) {  /* check that array was allocated */
    for (i = 0; i < numberOfPrimes; ++i) {
        primeArray[i] = 1;
    }
}

您的malloc调用从系统请求16g内存。如果您没有那么多的空闲虚拟内存,或者您在任何32位系统上运行,则调用将失败。如果您不检查malloc是否失败(您的代码没有检查),那么数组将是NULL,并且后续对其元素的任何访问都将导致分段错误。

如果你真的需要处理这么大的数组,你要么需要一个64位的系统,有很多内存,要么重写你的程序来处理一个更小的工作集,并将其余的保存到磁盘。