calloc()比malloc()&memset()慢

我想问你一个问题.我有以下代码
#include <stdio.h>
#include <stdlib.h>
#include <unistd.h>

#define XXX 1024*1024

int main()
{
        int *p;
        unsigned long x=0;
        while (1)
        {
                //p = (int *) calloc (1,XXX);
                p = (int *) malloc (XXX);
                memset (p,XXX);
                x++;
                printf ("%lu MB allocated.\n",x);
                sleep (1);
        }
        return 0;
}

如果我运行此代码,一切都正常运行.每秒,在内存中分配一个新的MB.我遇到的问题是,如果我取消注释calloc()行并注释malloc()和memset()行.据我所知,calloc()应该在分配的内存中将所有字节初始化为零;与malloc()和memset()相同的事情.

当我使用calloc()运行代码(没有malloc()和memset())时,分配初始的1 MB(正常),然后在几秒(~10)之后分配另一个MB.

为什么会这样?

提前致谢!

解决方法

From what I kNow,calloc() should initialize all bytes to zero in the allocated memory.

基于我对calloc调用的理解,这部分是正确的.

它保留空间但不会将所有内存初始化为零.它通常或通常将一个部分初始化为零,并将所有其他部分指向该部分;当在此块中修改或访问内存时,它将在使用前将其初始化为零.这意味着非常大的calloc调用不会将所有内存多次设置为零,而是仅在实际需要时才设置.

tl; dr:这是一个OS理论技巧,内核会作弊.这里有一个更长的描述:https://stackoverflow.com/a/2688522/2441252.

相关文章

本程序的编译和运行环境如下(如果有运行方面的问题欢迎在评...
水了一学期的院选修,万万没想到期末考试还有比较硬核的编程...
补充一下,先前文章末尾给出的下载链接的完整代码含有部分C&...
思路如标题所说采用模N取余法,难点是这个除法过程如何实现。...
本篇博客有更新!!!更新后效果图如下: 文章末尾的完整代码...
刚开始学习模块化程序设计时,估计大家都被形参和实参搞迷糊...