在C语言中是利用库函数malloc和free来分配和撤 销内存空间的。
C++提供了较简便而功能较强的运算符new和delete来取代 malloc和free函数
new int;
//开辟⼀个存放整数的存储空间,返回⼀个指向该存储空间的地址(即指针)
new int(100);
//开辟⼀个存放整数的空间,并指定该整数的初值为100,返回⼀个指向该存储空间的地址
new char[10];
//开辟⼀个存放字符数组(包括10个元素)的空间,返回⾸元素的地址
new int[5][4];
//开辟⼀个存放⼆维整型数组(⼤⼩为5*4)的空间,返回⾸元素的地址
float *p=new float (3.14159);
//开辟⼀个存放单精度数的空间,并指定该实数的初值为//3.14159,将返回的该空间的地址
赋给指针变量p
new运算符动态分配堆内存:
使用形式:指针变量=new类型(常量)
指针变量=new类型(表达式)
作用:从堆分配一块“类型”大小的储存空间,返回首地址。(常量是初始化值,可缺省。创建数组对象时,不能为对象指定初始值)
malloc不会调用类的构造函数,而new会调用类的构造函数
拷贝构造函数(克隆函数java)
由己存在的对象,创建新对象。也就是说新对象,不由构造器来构造,而是由 拷贝 构造器来完成。拷贝构造器的格式是固定的。
深拷贝与浅拷贝
浅拷贝:对象初始化对象的时候调动拷贝构造函数,只是拷贝指针指向的拷贝构造。
深拷贝:对象初始化对象的时候调动拷贝构造函数,真实开辟空间拷贝数据的拷贝构造。
系统提供默认的拷贝构造器,一经定义不再提供。但系统提供的默认拷贝 构造器是 等位拷贝,也就是通常意义上的浅拷贝。如果类中包含的数据元素全 部在栈上,浅拷贝 也可以满足需求的。但如果堆上的数据,则会发生多次析构行 为。