class A
{
public:
A(int i, int = 0){}
private:
int a, b;
};
class B
{
public:
//无需构造函数,因为数据成员的全部为public
int a, b, c;
};
int main()
{
A a = 3;
B b = {1, 2, 3};
// A *pa = new A[10];
B *pb = new B[10];
delete[] pb;
// vector<A> va(100);
vector<B> vb(100);
A c(a); //使用系统提供的行为,不能叫默认拷贝构造函数,叫“缺省按成员初始化”
return 0;
}
int *pia = new int[10];
我们并不能给动态分配的数组每个元素一个初始化值,语法并不支持
基于这个原因,对于对象数组
如果并没有默认构造函数,不能创建动态对象数组,因为new对象数组的时候,自动调用构造函数以建立对象,(new不只是分配内存而已,而且给编译器标识出这块内存存放的是什么类型的对象,int,class A,这也属于new的行为,所以它调用构造函数,以提供识别数据类型,解析二进制数据流的能力)如果并没有默认构造函数,
语法上不支持逐个初始化列表给动态数组,这样就没法构造对象了
容器vector和内置数组类型,是一个道理,
关键在于理解:new的动作不只是分配内存,而且进行类型标识的行为
{
public:
A(int i, int = 0){}
private:
int a, b;
};
class B
{
public:
//无需构造函数,因为数据成员的全部为public
int a, b, c;
};
int main()
{
A a = 3;
B b = {1, 2, 3};
// A *pa = new A[10];
B *pb = new B[10];
delete[] pb;
// vector<A> va(100);
vector<B> vb(100);
A c(a); //使用系统提供的行为,不能叫默认拷贝构造函数,叫“缺省按成员初始化”
return 0;
}
int *pia = new int[10];
我们并不能给动态分配的数组每个元素一个初始化值,语法并不支持
基于这个原因,对于对象数组
如果并没有默认构造函数,不能创建动态对象数组,因为new对象数组的时候,自动调用构造函数以建立对象,(new不只是分配内存而已,而且给编译器标识出这块内存存放的是什么类型的对象,int,class A,这也属于new的行为,所以它调用构造函数,以提供识别数据类型,解析二进制数据流的能力)如果并没有默认构造函数,
语法上不支持逐个初始化列表给动态数组,这样就没法构造对象了
容器vector和内置数组类型,是一个道理,
关键在于理解:new的动作不只是分配内存,而且进行类型标识的行为