new、delete和malloc、free

                          参考链接:http://blog.jobbole.com/109483/
     在c的时候,我们学习了当事先不确定要开辟多大内存的时候我们可以选择用malloc函数进行动态的内存开辟。现在学习c++呢,我们也有类似的操作,只是呢用法上会有一些出入,我们先来看一下使用上的区别。
一、使用
1、malloc和free
#include
  函数原型:(void*) malloc(size_t n);
  int *=(int*)malloc(sizeof(int)*10);
 
  这个函数使用上较为简单,有兴趣的同学可以类比依稀它还有另外的两个版本,回顾一下我们c语言的知识,我们在这里就不回顾了。对于这个函数我们的理解上要注意以下几点:
   
    1)我们malloc里只接收要开辟的内存大小,也就是说它接受的是实参是多少个
字节。
    2)我们malloc成功返回的是的是直向这块内存的一个void*类型的指针,它只
负责开辟多大的内存,并不关心你用它放什么数据,所以给用户返回的是void*类型
的指针,提供给用户使用上的自由。
    3)我们可以将得到的void*指针强转成我们这块所需要存放的数据类型。
    4)通常,我们都是将函数的返回值强转然后用一个相同类型的指针接受我们
动态开辟的空间的起始地址,并通过它去使用这个指针。
    5)我们需要注意的是动态开辟的空间都需要释放,不然它在程序的运行期间,会一直占用堆上的资源,产生的问题也就是我们所说的内存泄漏。当然程序要想在内存上运行,它得产生相应的进程,所以当我们程序运行结束的时候,也就是进程结束的时候,肯定会释放掉进程 所占用的的资源,堆上的资源肯定有时候会释放的,只是说作为一名合格的程序员,我们能及时解决并且能自己解决的问题,不要全都丢给操作系统,它要干的事情太多了,我们能做的尽量自己做。
   
   6)使用结束后,我们可以自己利用free函数将它释放掉。

2、delete和new
这两个关键字,是我们c++中才有的,c中没有。new也可以开辟动态内存,使用方法:
1)int *p=new int;//未初始化
2) int *p=new int();//会调用int的默认构造函数0
3)int *p=new int(10); // 用10初始化*p
4)string *p=new string;  //默认初始化 ,会调用它的构造函数进行初始化

   delete []p 和delete p的区别——见上篇博客

1和2的区别在哪呢?
new会分配内存,并且可以进行初始化。
delete,如果是对象会调用析构函数,并且释放对象所占内存
malloc 和free只会申请或释放所占内存。
 
注意:
1、不管是我们的free还是delete都不能同时释放一块内存两次,因为我们第一次释放之后,系统就给这块区域标识为空闲,表示可以被分配出去了,如果释放了一次,再释放,此时放了其他进程的有效数据呢,操作系统不会让这类事情放生,所以,如果释放同一块内存两次,操作系统会报错。通常,我们对指向原来动态内存空间的指针释放内存空间之后的处理是将这个指针置空。因为我们free和delete都做了释放指针所指向的堆上内存这件事情,如果是空,说明没有所占内存,操作系统什么都不干就行,并不会报错。
2、如果将指向内存的指针强制转成void *,再释放的话,会有一个问题,delete释放void* 所指向的对象时,并不会调用析构函数,只是释放内存,这样可能会有内存泄漏资源没有得到及时释放的问题。

猜你喜欢

转载自blog.csdn.net/betty2017/article/details/78696799