malloc与new函数详解

malloc函数
原型:extern void *malloc(unsigned int num_bytes);

用法:#include <malloc.h>

功能:分配长度为num_bytes字节的内存块

说明:如果分配成功则返回指向被分配内存的指针,否则返回空指针NULL。
当内存不再使用时,应使用free()函数将内存块释放。

举例:
// malloc.c

#include <syslib.h>
#include <malloc.h>
main()
{
char *p;

clrscr(); // clear screen
p=(char *)malloc(100);
if(p)
printf("Memory Allocated at: %x",p);
else
printf("Not Enough Memory!/n");
free(p);

getchar();
return 0;
}

函数声明(函数原型):
void *malloc(int size);
说明:malloc 向系统申请分配指定size个字节的内存空间。返回类型是 void* 类型。void* 表示未确定类型的指针。C,C++规定,void* 类型可以强制转换为任何其它类型的指针。
从函数声明上可以看出。malloc 和 new 至少有两个不同: new 返回指定类型的指针,并且可以自动计算所需要大小。比如:
int *p;
p = new int; //返回类型为int* 类型(整数型指针),分配大小为 sizeof(int);
或:
int* parr;
parr = new int [100]; //返回类型为 int* 类型(整数型指针),分配大小为 sizeof(int) * 100;
而 malloc 则必须由我们计算要字节数,并且在返回后强行转换为实际类型的指针。
int* p;
p = (int *) malloc (sizeof(int));
第一、malloc 函数返回的是 void * 类型,如果你写成:p = malloc (sizeof(int)); 则程序无法通过编译,报错:“不能将 void* 赋值给 int * 类型变量”。所以必须通过 (int *) 来将强制转换。
第二、函数的实参为 sizeof(int) ,用于指明一个整型数据需要的大小。如果你写成:
int* p = (int *) malloc (1);
代码也能通过编译,但事实上只分配了1个字节大小的内存空间,当你往里头存入一个整数,就会有3个字节无家可归,而直接“住进邻居家”!造成的结果是后面的内存中原有数据内容全部被清空。
malloc 也可以达到 new [] 的效果,申请出一段连续的内存,方法无非是指定你所需要内存大小。
比如想分配100个int类型的空间:
int* p = (int *) malloc ( sizeof(int) * 100 ); //分配可以放得下100个整数的内存空间。
另外有一点不能直接看出的区别是,malloc 只管分配内存,并不能对所得的内存进行初始化,所以得到的一片新内存中,其值将是随机的。
除了分配及最后释放的方法不一样以外,通过malloc或new得到指针,在其它操作上保持一致。

对其做一个特例补充
char *ptr;
if ((ptr = (char *)malloc(0)) == NULL)
puts("Got a null pointer");
else
puts("Got a valid pointer");
此时得到的是Got a valid pointer。把0赋给maclloc能得到一个合法的指针。


struct hostent *hp;

//注意是sizeof( sturct hostent )而不是sizeof( sturct hostent* )
//其中N代表你需要的sturct hostent类型数据的数量
hp = ( struct hostent* ) malloc ( N * sizeof( sturct hostent ) );

if ( !hp )      //建议要加上这个内存分配成功与否的检测
{
       // 添加内存分配失败时的处理方法
}


new delete, free malloc

首先应该知道malloc 和free是匹配的;new和delete是匹配的,他们不可以混淆。   

malloc和new都申请空间,但是new是强类型的分配,会调用对象的构造函数初始化对象,而malloc仅分配内存空间但是不初始化。

new   自适应类型,malloc需要强制转换new按类型进行分配,malloc需要指定内存大小对于对象来说free的确释放了对象的内存,但是不调用对象的析构函数。delete不仅释放对象的内存,并且调用对象的析构函数所以在对象中用free删除new创建的对象,内存就有可能泄露在delete内部仍调用了free .

补充一点:new和malloc虽然都是申请内存,但申请的位置不同,new的内存从free store分配,而malloc的内存从heap分配(详情请看ISO14882的内存管理部分),free store和heap很相似,都是动态内存,但是位置不同,这就是为什么new出来的内存不能通过free来释放的原因。不过微软编译器并没有很好的执行标准,很有可能把free store和heap混淆了,因此,free有时也可以。

再补充一点:delete时候不需要检查NULL

delete   NULL;      是没有任何问题的,所以     

if(p)     

{                 

delete   p;                 

p   =   NULL;     

}     

还不如     

delete   p;     

p   =   NULL;

而free(NULL)那就麻烦大了。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
mallocnew是用于动态分配内存的两种方法。 malloc是C语言中的函数,用于在堆上动态分配内存。它的函数原型是void *malloc(size_t size),返回一个指向分配内存的指针。分配的内存大小由size参数指定。malloc分配的内存位于堆上,可以使用free函数释放。 new是C++中的关键字,用于在自由存储区(可以是堆或静态存储区)动态分配内存。new的使用方式有两种:newnew\[\]。new用于分配单个对象的内存,而new\[\]用于分配数组的内存。new返回一个指向分配内存的指针。分配的内存大小由对象的类型决定。new分配的内存可以使用delete来释放,而new\[\]分配的内存应使用delete\[\]来释放。 虽然newmalloc都可以用于动态分配内存,但它们之间有一些区别。首先,new是C++的关键字,而malloc是C语言的函数。其次,new分配的内存位于自由存储区,而malloc分配的内存位于堆上。此外,newdelete是操作符,可以重载,而malloc和free是函数,不能重载。最后,由于newmalloc使用不同的内存管理机制,所以不能混合使用。也就是说,不能使用malloc分配的内存使用delete释放,反之亦然。 引用\[1\]解释了为什么new\[\]分配的空间用free()释放会出错,因为new\[\]分配空间返回的地址并不是它里面malloc分配空间的首地址,系统预留了sizeof(int)个字节。引用\[2\]说明了new分配的内存空间所在位置是自由存储区,而malloc在堆上动态分配内存。引用\[3\]提到了operator new /operator delete的实现可以基于malloc,而malloc的实现不可以去调用new。 #### 引用[.reference_title] - *1* [C++ malloc/free/new/delete详解(内存管理)](https://blog.csdn.net/TABE_/article/details/122179176)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^koosearch_v1,239^v3^insert_chatgpt"}} ] [.reference_item] - *2* *3* [newmalloc的区别](https://blog.csdn.net/Dr_Cassie/article/details/96494444)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^koosearch_v1,239^v3^insert_chatgpt"}} ] [.reference_item] [ .reference_list ]

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值