alloc

malloc calloc 区别
分类: 函数

函数malloc()和calloc()都可以用来动态分配内存空间,但两者稍有区别

malloc()函数有一个参数,即要分配的内存空间的大小:

void*malloc(size_tsize);

calloc()函数有两个参数,分别为元素的数目和每个元素的大小,这两个参数的乘积就是要分配的内存空间的大小。

void*calloc(size_tnumElements,size_tsizeOfElement);

如果调用成功,函数malloc()和函数calloc()都将返回所分配的内存空间的首地址。

函数malloc()和函数calloc() 的主要区别是前者不能初始化所分配的内存空间,而后者能。如果由malloc()函数分配的内存空间原来没有被使用过,则其中的每一位可能都是0;反之, 如果这部分内存曾经被分配过,则其中可能遗留有各种各样的数据。也就是说,使用malloc()函数的程序开始时(内存空间还没有被重新分配)能正常进 行,但经过一段时间(内存空间还已经被重新分配)可能会出现问题。

函数calloc() 会将所分配的内存空间中的每一位都初始化为零,也就是说,如果你是为字符类型或整数类型的元素分配内存,那麽这些元素将保证会被初始化为0;如果你是为指 针类型的元素分配内存,那麽这些元素通常会被初始化为空指针;如果你为实型数据分配内存,则这些元素会被初始化为浮点型的零。

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

char* p;

p=(char*)malloc(20);

callocmalloc相似,参数nelem为申请地址的单位元素长度,elsize为元素个数,如:

char* p;

p=(char*)calloc(sizeof(char),20);

这个例子与上一个效果相同

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

如:

char* p;

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

p=(char*)realloc(p,sizeof(char)*40);

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

C语言的标准内存分配函数:malloccallocrealloc,free等。

malloccalloc区别为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函数。

malloc的功能是确保内存空间使用字节。比如限定100,函数使用方法:

  (char *)malloc(100)   

超过100就会出错。

程序例:

#include <stdlib.h>

#include <stdio.h>

//#include <malloc.h>

void main( void )

{

 char *str;

 str = (char *)malloc(100);

 if( str == NULL )

  printf( "不能确保内存领域。/n" );

 else

  printf( "可以确保100字节内存。/n" );

 

 free( str ); 

 printf( "解放内存。/n" );

 getchar();

}

------------------------------------------------------------------

calloc则限定了每个要素的内存使用字节量

例:(char *)calloc(4,100);

程序例:

#include <stdlib.h>

#include <stdio.h>

//#include <malloc.h>

void main( void )

{

 char *str;

 str = (char *)calloc(4,100);

 if( str == NULL )

  printf( "不能确保内存领域。/n" );

 else

  printf( "可以确保4x100字节内存。/n" );

 free( str );

 printf( "解放内存。/n" );

 getchar();

}

首先看个问题程序(这里用的是TC编译器):

#include "stdlib.h"

#include "stdio.h"

void main()

{

   int *i;

   i=(int *)malloc(sizeof(int));

   *i=1;

   *(i+1)=2;

   printf("%x|%d/n",i,*i);

   printf("%x|%d",i+1,*(i+1));

}

输出的结果是:

8fc|1

8fe|2

这个程序编译通过,运行正常,说它有问题,问题出在哪呢?

首先通过malloc,建了一个大小为2的堆,

i指向的地址是8fc,i+1指向的地址是8fc+sizeof(int)=8fe

但是地址8fe是不受保护的,因为它不是机器分配给i+1的,随时会被其他变量占用。

正确的做法是

#include "stdlib.h"

#include "stdio.h"

void main()

{

   int *i;

   i=(int *)malloc(sizeof(int));

   *i=1;

   i=(int *)realloc(i,2*sizeof(int));

   *(i+1)=2;

   printf("%x|%d/n",i,*i);

   printf("%x|%d",i+1,*(i+1));

}

realloc 可以对给定的指针所指的空间进行扩大或者缩小,无论是扩张或是缩小,原有内存的中内容将保持不变。当然,对于缩小,则被缩小的那一部分的内容会丢失。realloc 并不保证调整后的内存空间和原来的内存空间保持同一内存地址。相反,realloc 返回的指针很可能指向一个新的地址。

所以,在代码中,我们必须将realloc返回的值,重新赋值给 p :

p = (int *) realloc (p, sizeof(int) *15);

甚至,你可以传一个空指针(0)给 realloc ,则此时realloc 作用完全相当于malloc

int* p = (int *) realloc (0,sizeof(int) * 10);  //分配一个全新的内存空间,

这一行,作用完全等同于:

int* p = (int *) malloc(sizeof(int) * 10);

『附注:TC编译器里sizeof(int)=2,VC里面sizeof(int)=4;

char型在两个编译器里是一样的,都是1个字节(8位)』

callocmalloc相似,参数nelem为申请地址的单位元素长度,elsize为元素个数,如:

char* p;

p=(char*)calloc(sizeof(char),20);

这个例子与上一个效果相同

 

 
### 关于 `malloc` 和 `alloc` 内存分配函数的功能区别与使用方法 #### `malloc` 函数详解 `malloc()` 是用于动态内存分配的标准库函数之一,在 C 语言中广泛应用于堆内存管理。此函数接收一个参数——所需字节数,并返回指向已分配内存区域的指针,类型为 `void *` 。需要注意的是,`malloc()` 不会初始化所分配的空间;因此,新分配的内存在初次使用前可能存在任意值[^1]。 对于如下代码片段: ```c int *ptr; ptr = (int *)malloc(sizeof(int)); if(ptr == NULL){ // 处理错误情况 } else{ *ptr = 10; // 正常情况下赋初值 } ``` 上述例子展示了如何利用 `malloc()` 来获取一段整数大小的连续地址空间并对其进行安全操作。值得注意的是,当不再需要这块内存时应当调用 `free()` 进行释放以防止泄漏。 #### `calloc` 函数解析 不同于 `malloc()` ,`calloc()` 可以为数组形式的数据结构提供服务。它接受两个参数:元素数目以及单个元素占用的字节长度。更重要的一点在于,`calloc()` 自动将所有位设置为零,从而避免了未定义行为的发生[^5]。 下面是一个简单的实例来说明这一点: ```c double *array_ptr; size_t num_elements = 10; // 请求一块能够容纳十个双精度浮点数值的地方 array_ptr = (double *)calloc(num_elements, sizeof(double)); if(array_ptr != NULL){ array_ptr[9] = 3.14; // 安全地向最后一个位置写入有效数据 } // 记得适时清理资源 free(array_ptr); ``` 这段示范体现了 `calloc()` 的优势所在,即不仅简化了程序员的工作量而且提高了程序健壮性。 #### `alloc` 并不是标准C的一部分 提到 `alloc` 却发现这不是 C 标准库里正式认可的名字。实际上可能是提问者混淆了一些概念或者是特定平台下的扩展实现。通常讨论里涉及到了诸如 `alloca()` 或其他变体名称,但这些都不是跨平台通用的选择。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值