C++【内存管理】
C语言中的动态内存管理
int main()
{
int* p2=(int*)calloc(4,sizeof(int));
int* p3=(int*)realloc(p2,sizeof(int)*10);
free(p3);
}
这里因为扩容数据小,所以是原地扩容,p2p3地址一样,不用free(p2)
如果扩容空间大就不是原地扩容,而是新找一块空间,然后拷贝
C++内存管理方式
new/delete(调用构造函数/析构函数)
int*ptr=new int;//申请一个int
int* ptr2=new int(10);//申请一个int并初始化为10
int*ptr3=new int[3];//申请3个int
int*ptr4=newnew[10]{1,2,3};//前三个初始化,后面自动为0
delete ptr;
delete ptr2;
delete ptr3[];//内存释放
new/delete底层原理
//核心操作=>operate new+构造函数(new失败了抛异常)
A*p2=new A(1,1);
//核心操作:析构函数+operate delete
delete p2;
A* a7=new A[10];
delete a7;//错误
A* a7=new A[10];
delete[ ] a7;//四个字节用来存储个数,正确
malloc/free和new/delete的区别
malloc/free和new/delete的共同点是:都是从堆上申请空间,并且需要用户手动释放。不同的地
方是:
- malloc和free是函数,new和delete是操作符
- malloc申请的空间不会初始化,new可以初始化
用法 - malloc申请空间时,需要手动计算空间大小并传递,new只需在其后跟上空间的类型即可,
如果是多个对象,[]中指定对象个数即可 - malloc的返回值为void*,在使用时必须强转,new不需要,因为new后跟的是空间的类型
- malloc申请空间失败时,返回的是NULL,因此使用时必须判空,new不需要,但是new需
要捕获异常 - 申请自定义类型对象时,malloc/free只会开辟空间,不会调用构造函数与析构函数,而new
功能
在申请空间后会调用构造函数完成对象的初始化,delete在释放空间前会调用析构函数完成空间中资源的清理释放
模版
函数模版
函数模版代表一个函数家族(T可以是任意类型)
泛型编程,针对任意类型
模版原理:通过模具编译器自动生成函数
template<class T>
void Swap(T& left ,T& right)
{
T temp=left;
left=right;
right=temp;
}
注意T不能一个int一个double,类型不同会推演错误
显示实例化:
Swap <int>(a1,d2);//或者
Swap<double>(a1,d2);
有非模版函数优先调用非模版函数,如果模版产生更好匹配的函数,就使用模版函数