当前位置: 首页 > news >正文

new和malloc的区别

newmalloc 都是在 C++ 中用于动态分配内存的方式,但它们之间有一些重要的区别

对象类型的区别:

  • new:new 是 C++ 的关键字,用于动态分配对象。它可以调用对象的构造函数进行初始化,并返回指向所分配对象的指针。
  • mallocmallocC 语言函数,用于动态分配内存空间。它只是分配了一块原始的内存空间,并不调用对象的构造函数。

内存分配大小的区别:

  • new:new 操作符在申请内存时会根据对象的类型自动计算大小。因此,你不需要显式指定分配的内存大小。例如:int p = new int;*。
  • malloc:malloc 函数在申请内存时需要显式指定分配的字节数。你需要通过 sizeof 运算符计算对象的大小并手动传递。例如:int p = (int)malloc(sizeof(int));**。

内存分配失败的处理:

  • **new:**如果内存分配失败,new 会抛出一个 std::bad_alloc 异常。
  • malloc:如果内存分配失败,malloc 会返回一个空指针(nullptr)作为分配失败的标志。

初始化对象和释放内存的方式:

  • new:new 在动态分配内存时会调用对象的构造函数进行初始化,在释放内存时会自动调用析构函数进行清理。你无需手动释放分配的内存,可以使用 delete 运算符来释放对象。
  • malloc:malloc 只是分配一块原始的内存空间,并不会调用对象的构造函数或析构函数。你需要手动调用对象的构造函数进行初始化,以及手动调用析构函数进行清理,并使用 free 函数释放内存。

兼容性和用途:

  • new:newC++ 的特性,它与对象的类型和构造函数密切相关,更适用于 C++ 对象的动态内存分配和释放。
  • malloc:mallocC 语言的函数,它分配的内存可以用于 C++ 对象,但需要手动调用构造函数和析构函数,适用于更底层、与 C 兼容性较高的场景。

在使用时,需要注意以下事项:

  • 对于 new,请使用 deletedelete[] 来释放动态分配的单个对象或数组。
  • -对于 malloc,请使用 free 来释放通过 malloc 分配的内存空间。
  • 避免混合使用 newmalloc,以免导致未定义行为。
  • C++ 中,更推荐使用 new 进行动态内存分配,因为它与对象的生命周期更好地集成在一起。

总之,newmalloc 在对象类型、内存分配大小、内存分配失败处理、初始化和释放内存的方式等方面存在差异。在使用时,要注意正确释放内存,并选择适合场景的方式。

http://www.lryc.cn/news/184479.html

相关文章:

  • python:openpyxl 读取 Excel文件,显示在 wx.grid 表格中
  • 12P2532X152 KJ3222X1-BA1 CE4003S2B1 EMERSON DELTAV
  • P1014 [NOIP1999 普及组] Cantor 表
  • JMeter性能分析实战一:日常登录接口
  • 内外网结合的多服务发布架构
  • Unity中Shader的光照模型Lambert
  • (一)Log4Net - 介绍
  • [bug] mysql 时间与本地不一致
  • 【改造先序遍历】222. 完全二叉树的节点个数
  • windows文件和目录相关命令
  • TL-ER3220G端口映射设置
  • MySQL Cluster
  • Spring封装的原生WebSocket使用,带组的实现
  • Linux高性能服务器编程 学习笔记 第十一章 定时器
  • jenkins拉取git代码 code 128解决方案
  • 【Linux】 ls命令使用
  • 【CVE-2023-35843】NocoDB 任意文件读取漏洞
  • 在 ubuntu 22.04 上配置界面服务器 vnc
  • 强化学习------Sarsa算法
  • [HNCTF 2022 WEEK2]easy_unser - 反序列化+wakeup绕过+目录绕过
  • FastThreadLocal 快在哪里 ?
  • ggkegg | 用这个神包玩转kegg数据库吧!~(一)
  • 【小黑送书—第三期】>>《深入浅出SSD》
  • linux虚拟机查看防火墙状态
  • Docker 安装 MongoDB
  • c++解压压缩包文件
  • MySql学习笔记:MySql性能优化
  • 机器学习(四十八):粒子群优化(PSO)-提升机器学习模型准确率的秘密武器
  • MySQL - mysql服务基本操作以及基本SQL语句与函数
  • [图论]哈尔滨工业大学(哈工大 HIT)学习笔记16-22