c语言malloc和calloc使用心得

    技术2025-11-17  14

    在c 中局部变量 静态变量 形参的内存是栈内存 是编译器分配的 而堆内存是用来存储结构 对象等信息

    可以使用指针等操作 指针需要分配足够的内存  使用malloc calloc等方法

     

    而且返回来的内存是个指针也就是个数组 使用指针 指针就会执行首地址

     

    比如 c++中使用new 和delete来分配内存

    char* c=new char[100];

     delete c

     

    realloc是给一个已经分配了地址的指针重新分配空间,参数ptr为原有的空间地址,newsize是重新申请的地址长度

    void* realloc(void* ptr, unsigned newsize);

     

    malloc用于申请一段新的地址,参数size为需要内存空间的长度,如:

    char* p;p=(char*)malloc(20);

    void* malloc(unsigned size);

     

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

    void* calloc(size_t nelem, size_t elsize);

    都在stdlib.h函数库内

    情景1: char *str="";   

    //到这一句就报错了 因为堆内存不够 strcpy(str, "Hellooooo");     printf("String is %s/n", str);   free(str);  

    情景2:

     char *str="";    if ((str = (char*)malloc(1)) == NULL)  {       printf("Not enough memory to allocate buffer/n");    }   strcpy(str, "Hellooooo");     printf("String is %s/n", str); 

    //在这里报错 因为空间只有1 Hellooooo占用的空间明显大于1 所以肯定是编译器开启的新空间 所以不是malloc的空间

    //free只能释放malloc 或者calloc创建的空间

    //所以报错 free(str);

     

    情景3:

     char *str="";    if ((str = (char*)malloc(10)) == NULL)  {       printf("Not enough memory to allocate buffer/n");    }   str="Hello";     printf("String is %s/n", str); 

    //在这里报错 因为=是指向的意思 str 重新指向了一段新的内存 不是malloc出来的

    //free只能释放malloc 或者calloc创建的空间

    //所以报错 free(str);

     

    正确的写法

     

     char *str="";    if ((str = (char*)malloc(10)) == NULL)  {       printf("Not enough memory to allocate buffer/n");    } 

    //大小为10的内存 不能放10个字符只能放9个 因为c还有个/0 表示结尾 strcpy(str, "Hellooooo");     printf("String is %s/n", str);   free(str); 

     

     

     

    当然

    delete 也只能删除new 关键字创建的内存 和malloc 上面的情景是一摸一样的

    最新回复(0)