c ++中的new运算符+默认构造函数

时间:2015-03-29 12:39:54

标签: c++

这里已经讨论了这个问题 [链接] Does new[] call default constructor in C++?

作为一个初学者和自学者,会赞赏积极的评论,请不要将其概括为广泛,狭隘等等。

当我们使用new []时,每个元素都由默认构造函数初始化,除非类型是内置类型。默认情况下,内置类型保持单一化。

这里说的是默认构造函数初始化对象是什么意思? 是不是现在每个对象的键都被初始化为零(默认构造函数),因为当我打印p [2] .key时,这是真的。

如何检查默认构造函数是否初始化数组或不是int数组,它无法访问main中的成员键?

另外(i)打印垃圾值,但(ii)打印0;

class People
{
    public:
      int key;
    People()
    {
        key=0;
    }
};

int main()
{
   int count=5;
   People *p=new People[count];
   cout<< p[2].key;

   // int *arr=new int[count]; ...(i)
   //cout<<*(arr+2);

  //int *arr=new int[count](); ... (ii)
 //cout<<*(arr+2)<<endl;

 return 0;
}

1 个答案:

答案 0 :(得分:5)

初始化已分配数组的规则比调用的默认构造函数稍微复杂一些。标准实际上是这样说的(5.3.4 [expr.new]第7段,未完全引用):

  1. 使用new T[n]等新表达式时,值默认初始化
  2. 使用new T[n]()等新表达式时,值直接初始化。对于数组,只应用直接初始化的值初始化
  3. 默认初始化基本上意味着对于具有默认构造函数的类,默认构造函数被调用,对于没有用户定义的默认构造函数的类(即,当根本没有默认构造函数或默认构造函数使用{{1)默认时成员默认初始化。内置类型的默认初始化什么都不做,即默认的初始化内置类型未初始化,并且在初始化之前读取相应的对象会导致未定义的行为。

    值初始化意味着对于具有默认构造函数的类,将调用默认构造函数,对于没有默认构造函数的类,将对成员进行值初始化。内置类型的值初始化导致零初始化,零初始化为内置类型执行适当的初始化(对于整数和浮点类型为零,对于指针为null,= default为{ {1}}等。)。

    所以在你的三个例子中,你得到了:

    1. 使用false,您可以通过调用bool的默认构造函数来初始化new People[count]类型的count个对象。
    2. 使用People,您的People默认初始化,即未初始化,new int[count]和表达式count(相当于int)产生未定义行为。
    3. 使用*(arr + 2),您arr[2]初始化new int[count]()为零,即它们都为零。