C++内存管理

前言:哈喽小伙伴们,这篇文章我们将一起来学习C++的内存管理。

C++的内存管理基本完全复用C语言,那C++在C语言的基础上又会有哪些优化和提升呢???


目录

一.内存管理方式

二.malloc/free与new/delete的区别

总结


一.内存管理方式

在C语言中,我们通过malloc、celloc、realloc、free四个函数来动态管理内存。

而在C++中,我们同样可以使用上边的内存管理函数,同时也出现了新的管理方式:

通过new和delete操作符来进行动态内存管理,也就是我们常说的new一个对象

     int* p1 = new int;        //new1个int类型的对象给到p1指针
    delete p1;
    int* p2 = new int[10];        //new10个int类型的对象给到p2指针
    delete[] p2;
    int* p3 = new int(1);        //new1个int类型的对象给到p3并初始化为1
    delete p3;
    int* p4 = new int[10]{1,2,3,4,5,6,7,8,9,10};        //new10个int类型的对象给到p4并初始化
    delete[] p4;

在用法上,new用来开辟空间,delete用来销毁空间new使用起来比malloc等更加方便简洁,并且可以在创建时就初始化

 那么new的好处真的就只是简洁吗???当然不是。

我们之前使用C语言写单链表的时候,是怎么创建新节点的???:

SLLNode* CreatNode(SLLDataType x)
{
	SLLNode* newnode = (SLLNode*)malloc(sizeof(SLLNode));
		if (newnode == NULL)
		{
			perror("CreatNode->malloc");
			exit(-1);
		}
		newnode->data = x;	
		newnode->next = NULL;
		return newnode;
}

代码量非常的多,那我们现在来使用new创建节点:

class SLLNode
{
public:
	SLLNode(int val)
		:_val(val)
		,_next(nullptr)
	{}
private:
	int _val;
	SLLNode* _next;
};
int main()
{
	SLLNode* n1 = new SLLNode(1);
	SLLNode* n2 = new SLLNode(2);
	SLLNode* n3 = new SLLNode(3);
	return 0;
}

写一个单链表的类,并使用列表初始化,这些是创建单链表的基本步骤我们不考虑。

而实际创建新节点就只用main函数中的一行代码

C++内存管理_第1张图片

而且我们不用判断创建的节点是否为空,因为编译器会自动为我们抛出异常(日后会讲)。

这样的写法可比malloc简单,而且方便太多了。 


二.malloc/free与new/delete的区别

两种内存管理方式的共同点在于它们都是在堆上申请空间,并且需要手动释放,而不同点在于:

  1. malloc和free是函数,new和delete是操作符
  2. malloc申请空间需要手动计算空间大小并传递,new只需在其后跟上空间的类型即可,如果是多个对象,在[]指定对象的个数即可
  3. malloc的返回值是void*,在使用时必须进行强制类型转换,new不需要
  4. malloc申请空间失败时,返回NULL,因此必须判空,new不需要,但需要补获异常
  5. 申请自定义类型对象时,malloc/free只会开辟空间,不会调用构造函数和析构函数,new在申请空间后会调用构造函数完成对象的初始化,delete在释放空间前会调用析构函数完成空间中资源的清理

总结

 C++内存管理的知识相对较少,因为很多都沿用了C语言,所以我们就暂时分享这么多。

喜欢博主文章的小伙伴们记得一键三连哦,我们下期再见!

你可能感兴趣的:(c++,开发语言)