C++:内存管理(new和delete的使用以及底层原理、定位new表达式、malloc/free和new/delete的区别,内存泄漏)

本文介绍了C++内存管理的方式,包括new和delete操作符、定位new表达式、malloc/free的区别。详细讨论了new/delete如何调用构造函数和析构函数,以及内存泄漏的概念、分类和避免方法。还提到了operator new和operator delete的作用,以及如何利用智能指针防止内存泄漏。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

内存管理

C语言中动态内存管理方式:malloc/calloc/realloc和free

void* malloc(unsigned size);
void* calloc(size_t numElements, size_t sizeOfElement); 
void* realloc(void* ptr, unsigned newsize);  

都在stdlib.h函数库内,它们的返回值都是请求系统分配的地址,如果请求失败就返回NULL.
(1)函数malloc()
在内存的动态存储区中分配一块长度为size字节的连续区域,参数size为需要内存空间的长度,返回该区域的首地址.
(2)函数calloc()
与malloc相似,参数sizeOfElement为申请地址的单位元素长度,numElements为元素个数,即在内存中申请numElements*sizeOfElement字节大小的连续地址空间.
(3)函数realloc()
给一个已经分配了地址的指针重新分配空间,参数ptr为原有的空间地址,newsize是重新申请的地址长度.

void Test()
{
   
   
	//开辟一个整形的大小
	int* p1 = (int *)malloc(sizeof(int));
	free(p1);//释放p1
	//开辟一个整形的大小并初始化为4
	int* p2 = (int *)calloc(4, sizeof(int));
	//对p2进行扩容操作
	int* p3 = (int *)realloc(p2, sizeof(int)* 10);
	free(p3);//释放p3
}

如上代码不需要对p2进行释放,因为p3对其增容的时候将p2的数据拷贝过去之后会将p2进行释放。realloc可以对一段空间进行缩容吗?答案是可以的,但是缩容之后,后面缩掉的空间如果有数据的话就会丢失,缩容不会重新开辟一块空间。

一、C++内存管理方式

通过 new 和 delete 操作符进行动态内存管理

void Test()
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值