C语言 未定义未使用的数组的分段错误



我正在尝试编写一个简单的程序,以十六进制输出二进制文件(Game Boy ROM)的前 16 KB,以 16 位块为单位。但是,在for循环期间,我的程序总是会出现段错误,但是它总是在数组中的不同点出现段错误。这是代码:

#include <stdio.h>
#include <stdint.h>
int main ()
{
    uint16_t buffer[8000];
    FILE* ROM = fopen("rom.gb", "rb");
    if (ROM == NULL)
    {
        printf("Error");
        fclose(ROM);
        return 1;
    }
    fread(buffer, sizeof(buffer), 1, ROM);
    int i;
    for(i = 0; i < sizeof(buffer); ++i)
    {
        if (buffer[i] < 16)
        {
            printf("000%x ", buffer[i]);
        }
        else if (buffer[i] < 256)
        {
            printf("00%x ", buffer[i]);
        }
        else if (buffer[i] < 4096)
        {
            printf("0%x ", buffer[i]);
        }
        else
        {
            printf("%x ", buffer[i]);
        }
    }
    fclose(ROM);
    return 0; 
}

在我更改为使用 uint16_t 而不是 char 之前(因为 Game Boy 有一个 16 位地址空间),这并没有发生,事实上,如果我包含声明

unsigned char buffer2[16000]; 

在第一个缓冲区的声明旁边,我得到了预期的输出。所以我的问题是,为什么添加一个未使用的变量会阻止程序出现段错误?我怎样才能避免这样做并声明一个在程序中完全未使用的巨大数组?

在这一行中:

for(i = 0; i < sizeof(buffer); ++i)

sizeof(buffer)是数组的大小(以字节为单位),如果您希望元素数使用

i < (sizeof(buffer) / sizeof(buffer[0]))

我不确定你是否正确使用fread,如果你看文档,第二个参数是每个元素的大小,而你传递的是整个缓冲区的大小。

您可能希望交换第二个和第三个参数,请参阅此处了解用法示例。

另请注意,正如 Alter Mann 所指出的,您需要将缓冲区的大小除以其类型的大小。

最新更新