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语言写单链表的时候,是怎么创建新节点的???:

cpp 复制代码
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创建节点:

cpp 复制代码
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函数中的一行代码

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

这样的写法可比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语言,所以我们就暂时分享这么多。

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

相关推荐
极客代码4 分钟前
【Python TensorFlow】进阶指南(续篇三)
开发语言·人工智能·python·深度学习·tensorflow
土豆湿10 分钟前
拥抱极简主义前端开发:NoCss.js 引领无 CSS 编程潮流
开发语言·javascript·css
小陈phd12 分钟前
Vscode LinuxC++环境配置
linux·c++·vscode
界面开发小八哥17 分钟前
更高效的Java 23开发,IntelliJ IDEA助力全面升级
java·开发语言·ide·intellij-idea·开发工具
火山口车神丶27 分钟前
某车企ASW面试笔试题
c++·matlab
qystca1 小时前
洛谷 B3637 最长上升子序列 C语言 记忆化搜索->‘正序‘dp
c语言·开发语言·算法
薯条不要番茄酱1 小时前
数据结构-8.Java. 七大排序算法(中篇)
java·开发语言·数据结构·后端·算法·排序算法·intellij-idea
今天吃饺子1 小时前
2024年SCI一区最新改进优化算法——四参数自适应生长优化器,MATLAB代码免费获取...
开发语言·算法·matlab
是阿建吖!1 小时前
【优选算法】二分查找
c++·算法
努力进修1 小时前
“探索Java List的无限可能:从基础到高级应用“
java·开发语言·list