zoukankan      html  css  js  c++  java
  • malloc与calloc区别

    一:它们都是动态分配内存,先看看它们的原型:

    void *malloc( size_t size ); //分配的大小

    void *calloc( size_t numElements, size_t sizeOfElement ); // 分配元素的个数和每个元素的大小

    共同点就是:它们返回的是 void * 类型,也就是说如果我们要为int或者其他类型的数据分配空间必须显式强制转换;

    不同点是:用malloc分配存储空间时,必须由我们计算需要的字节数。如果想要分配5个int型的空间,那就是说需要5*sizeof(int)的内存空间:

    int * ip_a;
    ip_a = (int*)malloc( sizeof (int) * 5 );

    而用calloc就不需要这么计算了,直接:

    ip_a = ( int* )calloc( 5, sizeof(int) );这样,就分配了相应的空间,而他们之间最大的区别就是:用malloc只分配空间不初始化,也就是依然保留着这段内存里的数据,而calloc则进行 了初始化,calloc分配的空间全部初始化为0,这样就避免了可能的一些数据错误。

    先写段代码体验体验....

    #include <iostream>

    using namespace std;

    void main()
    {
    int * ip_a;
    int * ip_b;


    ip_a = (int*)malloc( sizeof (int) * 5 );
    for( int i = 0; i < 5; i++ )
    {
       cin>>ip_a[i];
    }
    for( int j = 0; j < 5; j++ )
    {
       cout<<ip_a[j]<<" ";
    }


    ip_b = ( int* )calloc( 5, sizeof(int) );
    for( int j = 0; j < 5; j++ )
    {
       cout<<ip_b[j]<<" ";
    }


    }

    这个输出就能够清晰的看出他们的不同....

    ++版:

    三个函数的申明分别是:
    void* realloc(void* ptr, unsigned newsize);
    void* malloc(unsigned size);
    void* calloc(size_t numElements, size_t sizeOfElement);
    都在stdlib.h函数库内

    它们的返回值都是请求系统分配的地址,如果请求失败就返回NULL

    malloc用于申请一段新的地址,参数size为需要内存空间的长度,如:
    char* p;
    p=(char*)malloc(20);

    calloc与malloc相似,参数sizeOfElement为申请地址的单位元素长度,numElements为元素个数,如:
    char* p;
    p=(char*)calloc(20,sizeof(char));
    这个例子与上一个效果相同

    realloc是给一个已经分配了地址的指针重新分配空间,参数ptr为原有的空间地址,newsize是重新申请的地址长度
    如:
    char* p;
    p=(char*)malloc(sizeof(char)*20);
    p=(char*)realloc(p,sizeof(char)*40);

    注意,这里的空间长度都是以字节为单位。

    C语言的标准内存分配函数:malloc,calloc,realloc,free等。
    malloc与calloc的区别为1块与n块的区别:
    malloc调用形式为(类型*)malloc(size):在内存的动态存储区中分配一块长度为“size”字节的连续区域,返回该区域的首地址。
    calloc调用形式为(类型*)calloc(n,size):在内存的动态存储区中分配n块长度为“size”字节的连续区域,返回首地址。
    realloc调用形式为(类型*)realloc(*ptr,size):将ptr内存大小增大到size。
    free的调用形式为free(void*ptr):释放ptr所指向的一块内存空间。
    C++中为new/delete函数。

  • 相关阅读:
    第9课
    FreeRTOS 定时器组
    FMC—扩展外部 SDRAM
    FreeRTOS 事件标志组
    第8课
    FreeRTOS 系统时钟节拍和时间管理
    第七课 线性表的顺序存储结构
    手把手教你调试Linux C++ 代码(一步到位包含静态库和动态库调试)
    Windows GUI代码与Windows消息问题调试利器
    谈谈数据挖掘和机器学习
  • 原文地址:https://www.cnblogs.com/bayonetxxx/p/1602018.html
Copyright © 2011-2022 走看看