首页 > 系统相关 >【C++】内存管理

【C++】内存管理

时间:2024-03-31 10:59:02浏览次数:28  
标签:malloc 管理 int C++ 内存 operator new delete

在学习完类与对象后,在学习C++中,接下来需要学习的是内存管理,在本篇博客中将会讲解C++的内存管理。

 一.C/C++内存分布

在学习内存管理前,我们先来了解一下C/C++的内存分布。


 一般来说,内存可以分为四个区域:栈区、堆区、数据段、代码段。

栈区:用于存放非静态局部变量,函数参数、返回值等等。

堆区:用于存放动态内存开辟的空间,例如:malloc、calloc、realloc和new所生成的空间。

数据段:用于存放全局数据静态数据(被static修饰的就是静态数据)

代码段;用于存放可执行代码只读常量

二.C++内存管理方式

学过C语言的都知道,C语言的内存管理有malloc、calloc、realloc和free四个函数,而对于C++而言,内存管理只有new和delete操作符。 

#include<iostream>
using namespace std;

int main()
{
	int* tmp1 = new int;//申请一个int类型的空间
	int* tmp2 = new int[10];//申请一个int类型的数组
	int* tmp3 = new int(10);//申请一个int类型的空间,并初始化为10

	delete tmp1;//释放tmp1指向的空间
	delete[] tmp2;//释放tmp2指向的数组空间
	delete tmp3;//释放tmp3指向的空间
	return 0;
}

相比较与C语言,C++的内存管理方式更加方便好用。

同时,C++的方式和C语言相比,对于内置类型来说几乎没什么大区别,但是对于自定义类型来说有大区别,解释如下。

通过代码实现可以看到,malloc的方式就仅仅是去开辟一个空间,其他什么的没做,free也一样,只是去释放空间,其他什么都没做,

而new的方式可以看到,在new一个自定义类型时,会主动去调用它的构造函数,而且在delete时,也会主动调用它的析构函数,这个就是malloc、free和new、delete的区别。(这种情况仅对自定义类型有效

 三.operator new 与 operator delete函数

接下来先在这里引入两个函数:operator new 和 operator delete函数。

 operator new 和 operator delete是系统提供的两个全局函数,其实new在底层是通过调用operator new 函数来实现申请空间的,而delete在底层也是通过调用operator delete函数来实现释放空间的。

operator new

那么operator new和new又有什么区别呢?以及operator new 又是怎么实现的?

再往下一层看,其实 operator new 的底层是通过调用malloc来实现的。那为什么不直接用malloc,而是又引入一个operator new。因为malloc在申请空间失败的时候会返回一个空指针,而operator new在malloc的基础上,增加了申请空间失败的时候直接抛出异常(这里涉及到C++的异常处理,先不过多的解释)。


而operator new和new的区别就是,operator new仅仅是去申请空间,而new不仅去申请空间,申请完成后,对于自定义类型会去调用它的构造函数

operator delete

知道了operator new、malloc和new的区别,那么operator delete也一样。

其实operator delete 底层也是通过free来实现的,和free几乎没什么区别,那至于为什么要搞一个operator delete,是因为要保持一个对立的关系,即malloc对应free、operator new对应operator delete,new对应delete。

那operator delete和delete又有什么区别呢?

 operator delete仅仅是去释放一块空间,而delete在释放空间的基础上,对于自定义类型来说,会去调用它的析构函数

区别与联系 

  malloc\free和new\delete的区别

1.malloc\free是函数,new\delete是操作符

2.malloc申请的空间不会被初始化,而new会

3.malloc申请空间需要传递申请空间的大小,而new不用,后面只需接上要申请的类型即可

4.malloc返回值是void*,一般来说需要强转,而new不用

5.malloc申请失败是会返回空指针,需要进行检查,而new不用,失败直接抛出异常

6.free仅仅是去释放空间,而delete会去调用析构函数

标签:malloc,管理,int,C++,内存,operator,new,delete
From: https://blog.csdn.net/EWIAW_ilove/article/details/137093217

相关文章

  • 信息系统项目管理师——第11章项目成本管理(重要)
    选择、本章节内容属于10大管理知识领域中的重中之重案例、论文都会考,需要完全掌握。选择题大概考3分左右,理论和计算都会考。案例题,必考内容,挣值相关的计算,必须得会。论文题,考的比较多,建议作为第一梯队准备。1.管理基础重要性和意义项目成本管理的作用和意义项目成本......
  • 信息系统项目管理师——第12章项目质量管理
    本章节内容属于10大管理知识领域中的重点,选择、案例、论文都会考,而且是高频考点,需要我们重点学习。选择题,稳定考3分左右,新教材基本考课本原话,这个分不能丢。案例题,本期备考重点,需要好好学。论文题,22年11月刚考过,短期应该不会考。1.管理基础质量与项目质量定义:产品质......
  • 【2024年5月备考新增】《软考真题分章练习(含答案解析) - 14 组织级项目管理(高项)》
    1题目1、办公软件开发公司A非常重视软件过程管理,按照CMMI(能力成熟度模型)逐步进行过程改进,刚刚实现了组织级过程性能、定量项目管理,按照CMMI(能力成熟度模型),A公司达到了()级别。A.CMMI2B.CMMI3C.CMMI4D.CMMI52、CMMI的连续式表示法与阶段式表示法分别表示:()。A.项......
  • java毕业设计社团管理系统(Springboot+mysql+jdk1.8+maven3.39)
    本系统(程序+源码)带文档lw万字以上 文末可领取本课题的JAVA源码参考系统程序文件列表系统的选题背景和意义选题背景:随着高校教育的不断发展,学生社团作为校园文化的重要组成部分,承担着丰富学生课余生活、培养学生兴趣爱好、提升学生实践能力的重要职能。然而,传统的社团管......
  • java毕业设计实验室资源管理(Springboot+mysql+jdk1.8+maven3.39)
    本系统(程序+源码)带文档lw万字以上 文末可领取本课题的JAVA源码参考系统程序文件列表系统的选题背景和意义一、选题背景:在高等教育和科研机构中,实验室是进行教学和科学研究的重要场所。一个现代化的实验室通常拥有大量昂贵的设备、仪器和材料。如何有效地管理这些资源,确......
  • C++与C语言
    C++之所以是C++,和面向过程的C语言相比,它加了一个类,还有一个是模板。 引入C语言这种面向过程的编译语言可以将待解的问题分解成若干个子问题,面向对象程序设计则是建立在结构化程序设计方法的基础上,完全避免了结构化程序设计方法中所存在的问题。程序=数据结构+算法(结构化......
  • java毕业设计天勤人力资源管理(Springboot+mysql+jdk1.8+maven3.39)
    本系统(程序+源码)带文档lw万字以上 文末可领取本课题的JAVA源码参考系统程序文件列表系统的选题背景和意义一、选题背景:在当今竞争激烈的商业环境中,人力资源管理(HRM)对于组织的成功至关重要。有效的HRM不仅能够提高员工的工作效率和满意度,而且可以促进企业的整体发展战......
  • java毕业设计数字家谱管理系统(Springboot+mysql+jdk1.8+maven3.39)
    本系统(程序+源码)带文档lw万字以上 文末可领取本课题的JAVA源码参考系统程序文件列表系统的选题背景和意义一、选题背景:在快速变化的社会中,人们越来越意识到家族历史和文化传承的重要性。家谱作为记录家族血脉和历史的重要文献,承载着丰富的文化价值和历史信息。然而,传统......
  • 数据结构 —— 线性表的链式存储(链表)(C++)
    目录单链表(有头结点)定义初始化判空销毁清空求表长取值查找插入删除创建头部创建尾部创建本文相关知识:以链式存储结构来实现线性表(C++)如有错误请指正~~谢谢~后面更新循环链表和双向链表单链表(有头结点)以带头结点的单链表为例,操作更加简便!定义首先,为了增强程序的可读性,做出以......
  • linux物理内存,虚拟内存的获取
    使用文件流的方式,解析   cat/proc/meminfo 文件里面的数据 #include<iostream>#include<fstream>#include<sstream>#include<string>#include<unordered_map>#include<map>structBASE_INFO_S{unsignedlonglongMemTot......