c++ 内存管理(newdeletedelete[])

因为在c++里面新增了类,所以我们在有时候会用malloc来创建类,但是这种创建只是单纯的开辟空间,没有什么默认构造的。同时free也是free的表面,如果类里面带有指针指向堆区的成员变量就会free不干净。

所以我们c++增加了new delete和delete[]来应对类的问题。

如果还有宝子不会c语言的内存管理的,可以看这一篇->C语言内存管理

new

创建一个整形:

创建一个内容是10的整形空间:

申请十个int类型的数组:

申请十个int类型数组,并初始化:

如果是类的内存申请,会是怎么样的呢?

我们发现类每次内存申请都会调用构造函数。

我们再看:

只要我们有数据初始化,那么会调用带参构造,反之就会调用默认构造。

那我那么申请后该如何释放呢?

delete和delete[]

我们申请的单个变量用delete,数组就用delete[]:

delete和delete[]的区别

这个需要先讲他们的底层:

1、new的底层就是现malloc,然后如果是自定义类型就调用对应的析构函数。

2、delete就是调用对应的析构函数,然后用free掉

3、而delete[]不一样的就是,我们用new来申请数组的时候,如果是自定义类型的数组,那么就会额外在这个数组前面开一个内存来存储它的长度,用来看有几个变量,这样的做法主要是为了释放自定义类型(类)的。

我们看如下举例来验证:

调试后我们看到的确如此

大家不信我们可以换一下长度:

我们走完全程发现析构了六次:

如果我们直接用delete来释放数组,只会释放第一个位置的内存就会崩掉:

原因就是:我们释放内存不能只释放一块,用delete只能释放第一个数据,前后的数据还在那,或者可能把后面的内存释放完了,但是前面的存储长度的内存没有释放。

那么根据这个原理,我应该可以用delete来释放没有类的数组:

确实如此:因为delete在没有类的情况下就是一个free函数。没有类的数组前面不会有一个空间记录长度,那么从p开始就可以直接free干净。但是不建议这么写。

内存申请失败的处理方法

在C语言里面,是判断返回值是否为NULL,在c++里面就是抛异常来解决。如果有异常,可以采取相关措施释放一些不必要的堆区内存然后重新申请达到处理的目的。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.rhkb.cn/news/386575.html

如若内容造成侵权/违法违规/事实不符,请联系长河编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Python --Pandas库基础方法(2)

文章目录 Pandas 变量类型的转换查看各列数据类型改变数据类型 重置索引删除行索引和切片seriesDataFrame取列按行列索引选择loc与iloc获取 isin()选择query()的使用排序用索引排序使用变量值排序 修改替换变量值对应数值的替换 数据分组基于拆分进行筛选 分组汇总引用自定义函…

springcloud RocketMQ 客户端是怎么走到消费业务逻辑的 - debug step by step

springcloud RocketMQ ,一个mq消息发送后,客户端是怎么一步步拿到消息去消费的?我们要从代码层面探究这个问题。 找的流程图,有待考究。 以下我们开始debug: 拉取数据的线程: PullMessageService.java 本…

126M全球手机基站SHP数据分享

数据是GIS的血液! 我们在《2.8亿东亚五国建筑数据分享》一文中,为你分享过东亚五国建筑数据。 现在再为你分享全球手机基站SHP数据,你可以在文末查看该数据的领取方法。 全球手机基站SHP数据 全球手机基站数据是OpenCelliD团队创建由社区…

【Spring Cloud】Sleuth +Zinkin 实现链路追踪并持久化的解决方案

文章目录 前言链路追踪介绍Sleuth入门Sleuth介绍TraceSpanAnnotation Sleuth入门1、引入依赖2、修改配置文件3、网关路由配置4、演示 Zipkin的集成ZipKin介绍ZipKin服务端安装Zipkin客户端集成1、添加依赖2、添加配置3、访问微服务4、演示 Zipkin数据持久化使用mysql实现数据持…

现代Java开发:使用jjwt实现JWT认证

前言 jjwt 库 是一个流行的 Java 库,用于创建和解析 JWT。我在学习spring security 的过程中看到了很多关于jwt的教程,其中最流行的就是使用jjwt实现jwt认证,但是教程之中依然使用的旧版的jjwt库,许多的类与方法已经标记弃用或者…

多家隧道代理价格:阿布云、快代理、小象代理、熊猫代理和亿牛云……

随着奥运的热度攀升,各大品牌也在抓紧时机赶上这波奥运热潮,随之而来的大量数据信息收集和分析工作也接踵而至,在这一数据采集过程中,HTTP代理的质量和价格对企业的效率和成本调控重要性不言而喻。我们大部分人在日常购买产品的时…

Revit中如何添加剖面?快速实现剖面图的方法汇总

Revit中创建剖面以及剖面视图一般有两种方法,一是使用Revit原生的剖面功能,而是使用Revit插件BIM建模助手进行便捷的剖面操作以及剖面视图创建。 Revit原生的剖面功能,点击后可以自由拉伸剖面方向、范围,放置完剖面符号后&#xf…

【ROS 最简单教程 003/300】ROS 快速体验:Hello World

开始自己的第一次尝试叭 ~ Hello World 本篇是 C 版本,如需 python 版本 👉 python 版本指路 ROS 中程序的实现流程: 创建工作空间 ( 💙 如 tutu_ws) ,进入并编译 mkdir -p tutu_ws/src cd tutu_ws catkin_make在 src …

【C语言】结构体详解 -《探索C语言的 “小宇宙” 》

目录 C语言结构体(struct)详解结构体概览表1. 结构体的基本概念1.1 结构体定义1.2 结构体变量声明 2. 结构体成员的访问2.1 使用点运算符(.)访问成员输出 2.2 使用箭头运算符(->)访问成员输出 3. 结构体…

springboot使用Gateway做网关并且配置全局拦截器

一、为什么要用网关 统一入口: 作用:作为所有客户端请求的统一入口。说明:所有客户端请求都通过网关进行路由,网关负责将请求转发到后端的微服务 路由转发: 作用:根据请求的URL、方法等信息将请求路由到…

Hive之扩展函数(UDF)

Hive之扩展函数(UDF) 1、概念讲解 当所提供的函数无法解决遇到的问题时,我们通常会进行自定义函数,即:扩展函数。Hive的扩展函数可分为三种:UDF,UDTF,UDAF。 UDF:一进一出 UDTF:一进多出 UDAF&#xff1a…

作业帮6-19笔试-选填题

可以看到10在第一位,说明用的是挖坑法快速排序,过程如下: 右指针从最右边开始,找到第一个比30小的数10,与30交换。 10、15、40、28、50、30、70 左指针从位置1开始,找到40,与30互换。 10、15、3…

C语言 ——— 函数指针的定义 函数指针的使用

目录 何为函数指针 打印 函数名的地址 及 &函数名的地址 函数指针的代码(如何正确存储函数地址) 函数指针的使用 何为函数指针 类比: 整型指针 - 指向整型数据的指针,整型指针存放的是整型数据的地址 字符指针 - 指向字…

Lc63---1859将句子排序(排序)---Java版(未写完)

1.题目描述 2.思路 (1)首先将句子按空格分割成若干单词。 (2)每个单词的最后一个字符是它的位置索引。我们可以通过这个索引将单词恢复到正确的位置。 (3)按照单词的索引顺序排序这些单词。 (4…

分布式搜索引擎ES--Elasticsearch集群

1.Elasticsearch集群的概念 分片机制:每个索引都可以被分片 索引my_doc只有一个主分片;索引shop有三个主分片;索引shop2有5个主分片;(参考前面案例) 每个主分片都包含索引的数据,由于目前是单机,所以副分片是没有的&a…

shardingsphere的学习(二):sharingjdbc操作读写分离

简介 mysql配置读写分离以及使用shardingjdbc配置操作读写分离 读写分离 主数据库负责增删改操作(写),从数据库负责查询操作(读),主数据库和从数据库之间会数据同步(主从复制)。 …

【前端】一文带你了解 CSS

文章目录 1. CSS 是什么2. CSS 引入方式2.1 内部样式2.2 外部样式2.3 内联样式 3. CSS 常见选择器3.1 基础选择器3.1.1 标签选择器3.1.2 类选择器3.1.3 id 选择器3.1.4 通配符选择器 3.2 复合选择器3.2.1 后代选择器 4. CSS 常用属性4.1 字体相关4.2 文本相关4.3 背景相关4.4 设…

敢不敢跟我一起搭建一个Agent!不写一行代码,10分钟搞出你的智能体!纯配置也能真正掌握AI最有潜力的技术?AI圈内人必备技能

说一千道一万,不如实地转一转。学了那么久的AI Agent的概念了,是时候该落地一个Agent看看自己的掌握程度了对不对,我们都理解大脑是自动节能的,但是知识的确需要倒逼自己一把才能真的掌握,不瞒大家说,笔者对…