malloc和new的本质区别

目录

一、结论

二、示例

1.实现类T

2.用malloc分配类T的内存空间

3.用new分配类T的内存空间


一、结论

mallocnew 都是用于在运行时动态分配内存的机制。但它们之间存在一些本质的区别,主要是在使用方面,现在我们直接说结论,然后在通过一个案例来理解和加深区别。

二、示例

1.实现类T

我们先来创建一个类T,代码比较简单,主要有一个静态的成员变量count。count作用用来计算创建类T实例数量的多少。代码如下:

class T
{
public:
	T()
	{
		a = 10;
		std::cout << "第" << ++count << "个T被构造了" << std::endl;
	}
	~T()
	{
		std::cout << "第" << count-- << "个T被销毁了" << std::endl;
	}
	static int count;
	
	int a;

};
// 初始化静态变量count
int T::count = 0;

需要注意:静态成员变量需要在类外初始化!

2.用malloc分配类T的内存空间

我们用malloc关键字动态分配10个类T大小的空间,同时测试构造函数和析构函数是否发生变化。代码和结果如下:

int main()
{
	T* t1 = (T*)malloc(sizeof(T) * 10);
	std::cout << t1->count << std::endl;
	// 释放空间
	free(t1);
}

得出的结果count为0,同时构造函数和析构函数没有触发。可见malloc 只会分配请求的内存大小,并返回一个指向该内存的指针,它不会调用任何构造函数。

3.用new分配类T的内存空间

与malloc同样,我们用new关键字动态分配10个类T大小的空间,同时测试构造函数和析构函数是否发生变化。代码和结果如下:

int main()
{
	T* t2 = new T[10];	
	std::cout << t2->count << std::endl;
	// 释放空间
	delete[] t2;
}

得出的结果count为10,同时构造函数和析构函数都会触发。所以new 不仅会分配内存,还会调用对象的构造函数(如果适用)。同样地,当使用 delete 运算符释放内存时,它会调用对象的析构函数。

相关推荐
清风fu杨柳20 分钟前
centos7 arm版本编译qt5.6.3详细说明
开发语言·arm开发·qt
醉颜凉23 分钟前
【NOIP提高组】潜伏者
java·c语言·开发语言·c++·算法
_小柏_25 分钟前
C/C++基础知识复习(20)
开发语言
hunandede30 分钟前
FFmpeg 4.3 音视频-多路H265监控录放C++开发十三.2:avpacket中包含多个 NALU如何解析头部分析
c++·ffmpeg·音视频
lapiii35831 分钟前
图论-代码随想录刷题记录[JAVA]
java·数据结构·算法·图论
程序员小明z35 分钟前
基于Java的药店管理系统
java·开发语言·spring boot·毕业设计·毕设
爱学习的大牛1231 小时前
通过vmware虚拟机安装和调试编译好的 ReactOS
c++·windows内核
我是哈哈hh1 小时前
HTML5和CSS3的进阶_HTML5和CSS3的新增特性
开发语言·前端·css·html·css3·html5·web
Dontla2 小时前
Rust泛型系统类型推导原理(Rust类型推导、泛型类型推导、泛型推导)为什么在某些情况必须手动添加泛型特征约束?(泛型trait约束)
开发语言·算法·rust