malloc、calloc、realloc的区别

详细区别:

内存来源和初始化

  • malloc:用于在堆区申请一块连续的指定大小的内存块区域,并以void*类型返回分配的内存区域地址。它不会进行内存初始化,即分配的内存区域可能包含任意数据。
  • calloc:与malloc类似,也是用于动态地分配内存空间,但calloc会在分配内存时自动将内存清零,即将分配的内存区域的每一位都初始化为零。因此,calloc也被称为"零初始化内存分配器"。
  • realloc:用于重新分配之前通过malloc、calloc或realloc分配的内存块。它允许改变已分配内存块的大小,并根据需要调整内存块的位置。

参数不同

  • malloc:函数接受一个参数,即需要分配的内存大小(以字节为单位),并返回一个指向分配内存的指针,如果分配失败则返回NULL。
  • calloc:函数接受两个参数,第一个参数表示要分配的元素个数,第二个参数表示每个元素的大小(以字节为单位)。它也返回一个指向分配内存的指针,如果分配失败则返回NULL。
  • realloc:函数接受两个参数,第一个参数是指向要重新分配的内存块的指针,第二个参数是要为新的内存块分配的字节数。它返回重新分配后的内存块的指针,如果重新分配失败则返回NULL。

内存泄漏问题

  • 无论是malloc、calloc还是realloc分配的内存,都需要在使用完毕后通过free函数来释放,以避免内存泄漏。内存泄漏可能会导致系统可用内存不断减少,最终影响程序的正常运行。

使用场景

  • malloc:适用于在程序运行时根据需要动态分配内存的情况,适用于不需要初始化的内存分配。
  • calloc:适用于需要分配并初始化内存的情况,特别是在分配数组或结构体等数据结构时,使用calloc可以避免手动初始化的繁琐操作。
  • realloc:适用于在已分配内存的基础上调整内存大小的情况,特别是在处理可变长数组或动态数据结构时非常有用。

示例:

以下是使用malloccallocrealloc函数的代码示例:

malloc 示例

cpp 复制代码
#include <stdio.h>
#include <stdlib.h>

int main() {

int *ptr;
int n = 5;



// 使用 malloc 分配内存
ptr = (int *)malloc(n * sizeof(int));
if (ptr == NULL) {

printf("Memory not allocated.\n");
exit(1);

}


// 初始化内存
for (int i = 0; i < n; i++) {
ptr[i] = i + 1;
}


// 打印数组内容

for (int i = 0; i < n; i++) {
printf("%d ", ptr[i]);

}

// 释放内存

free(ptr);

return 0;

}

calloc 示例

cpp 复制代码
#include <stdio.h>

#include <stdlib.h>



int main() {

int *ptr;

int n = 5;



// 使用 calloc 分配并初始化内存

ptr = (int *)calloc(n, sizeof(int));

if (ptr == NULL) {

printf("Memory not allocated.\n");

exit(1);

}



// 打印数组内容(应为0, 0, 0, 0, 0 因为 calloc 初始化了内存)

for (int i = 0; i < n; i++) {

printf("%d ", ptr[i]);

}



// 释放内存

free(ptr);



return 0;

}

realloc 示例

cpp 复制代码
#include <stdio.h> 
#include <stdlib.h> 


int main() { 
int *ptr; 
int n = 5; 


// 初始分配内存 
ptr = (int *)malloc(n * sizeof(int)); 
if (ptr == NULL) { 
printf("Memory not allocated.\n"); 
exit(1); 
} 


// 初始化内存 
for (int i = 0; i < n; i++) { 
ptr[i] = i + 1; 
} 


// 打印原始数组内容 
printf("Original array: "); 
for (int i = 0; i < n; i++) { 
printf("%d ", ptr[i]); 
} 


// 使用 realloc 扩大内存 
n *= 2; // 扩大为原来的两倍 
ptr = (int *)realloc(ptr, n * sizeof(int)); 
if (ptr == NULL) { 
printf("Memory not reallocated.\n"); 
exit(1); 
} 


// 初始化新分配的内存部分 
for (int i = n / 2; i < n; i++) { 
ptr[i] = i + 1; 
} 


// 打印扩大后的数组内容 
printf("\nExpanded array: "); 
for (int i = 0; i < n; i++) { 
printf("%d ", ptr[i]); 
} 


// 释放内存 
free(ptr); 


return 0; 
}

这些示例展示了如何使用malloccallocrealloc函数来分配、初始化和重新分配内存。注意,在使用这些函数时,一定要检查返回值是否为NULL,以确保内存分配成功。另外,在不再需要内存时,应使用free函数来释放内存,以避免内存泄漏。

相关推荐
谱写秋天2 小时前
FreeRTOS中断服务程序(ISR)详细讲解
c语言·freertos·isr
GUET_一路向前5 小时前
【C语言】解释形参void *data用法
c语言·开发语言·通用指针
pusue_the_sun6 小时前
数据结构——顺序表&&单链表oj详解
c语言·数据结构·算法·链表·顺序表
风铃7779 小时前
c/c++ Socket+共享内存实现本机进程间通信
linux·c语言
John.Lewis9 小时前
数据结构初阶(15)排序算法—交换排序(快速排序)(动图演示)
c语言·数据结构·排序算法
Cx330❀10 小时前
【数据结构初阶】--排序(三):冒泡排序、快速排序
c语言·数据结构·经验分享·算法·排序算法
lsnm10 小时前
【LINUX网络】HTTP协议基本结构、搭建自己的HTTP简单服务器
linux·运维·服务器·c语言·网络·c++·http
stone519514 小时前
TOTP算法与HOTP算法
c语言·物联网·算法·嵌入式·iot平台·智能门锁
的卢马飞快14 小时前
C语言指针(五):回调函数与 qsort 的深层关联
c语言·指针·qsort