微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

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.

原文地址:https://www.jb51.cc/c/119663.html

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐