Malloc函数内存分配大小问题

问题描述

我有一个非常简单的程序来演示C语言中malloc函数用法。我已分配了仅存储一个整数所需的大小,并将返回的指针存储在变量ptr中。

问题是,尽管我已将malloc大小设置为一个整数(在我的PC中为4个字节),但是当int x = 95;为0时,即使对于大量整数(printf("%u\n",ptr + j);),代码也可以正常运行未注释。但是当对printf("%u\n",ptr + j);进行注释时,会出现错误。尝试访问printf或其他内容时,它可能会创建一些相邻的内存块。

我认为这与是否使用内存堆有一定关系,但是作为一个初学者,我想对此进行解释。

谢谢。

#include <stdio.h>
#include <stdlib.h>

int main() {
    int *ptr;
    int x = 95;

    ptr = (int *) malloc(sizeof(int));
    for (int j = 0; j < x; ++j) {
        *(ptr + j) = 3;
        //printf("%u\n",ptr + j);
    }

    for (int i = 0; i < x; ++i) {
        printf("%d\n",*(ptr + i));
    }

    return 0;
}

解决方法

在您的示例中,您为一个整数分配了内存,并且您尝试写入95个整数。您应该始终分配足够的空间。在这种情况下,您应该 malloc(sizeof(int) * x);,然后用您的数字填充该空间:)

,

如果您要打印地址,请在打印语句中将%u更改为%p

,

您的代码会调用未定义的行为(以可能的最坏形式之一,即覆盖内存,这是软件中许多漏洞的根本原因)。

“未定义的行为”表示可能发生任何事情。绝对可以。您要问的是,更改代码后结果为什么会更改:因为您的行为不确定,所以任何事情都可能发生。当您看不到发生不同事情的充分理由时,可能会发生不同的事情。无论您采取什么假设,如果您的代码具有未定义的行为,那么您就是错误的。