构造和初始化列表:编译器做什么?

问题描述 投票:0回答:1

我对 C++ 中的构造函数有一些疑问。对于每个问题(从 (1) 到 (4)),我想知道该行为是否根据标准得到了完美定义。

A) 第一个是关于成员的初始化:

class Class
{
    public:
        Class() 
        : _x(0)
        , _y(_x)
        , _z(_y) // <- (1) Can I initialize a member with other members ?
        {
            ;
        }

    protected:
        int _x;
        int _y;
        int _z;
};

B) 编译器向每个类添加了哪些函数?

template<typename T> class Class
{
    public:
        template<typename T0>
        Class(const Class<T0>& other)
        {
            std::cout<<"My copy constructor"<<std::endl;
            _x = other._x;   
        }

        template<typename T0 = T>
        Class (const T0 var = 0)
        {
            std::cout<<"My normal constructor"<<std::endl;
            _x = var;
        }

    public:
        T _x;
};

// (2) Are 
// Class(const Class<T>& other) 
// AND 
// inline Class<T>& operator=(const Class<T>& other)
// the only functions automatically added by the compiler ?

举个例子,如果我打电话:

Class<int> a;
Class<int> b(a); // <- Will not write "My copy constructor"
Class<double> c(a); // <- Will write "My copy constructor"

(3) 根据标准,这种行为完全正常吗?

(4) 我是否可以保证不会自动添加空构造函数并且

Class<int> x;
会写
"My normal constructor"

c++ c++11 constructor standards-compliance
1个回答
6
投票

我可以与其他成员一起初始化一个成员吗?

是的,只要其他成员已经初始化;即只要他们的声明是在成员初始化之前进行的。

[复制构造函数]和[复制赋值运算符]是编译器自动添加的唯一函数吗?

它还会隐式声明一个析构函数,这将使用其析构函数销毁

_x

在 C++11 中,移动构造函数 (

Class(Class&&)
) 和移动赋值运算符 (
Class& operator=(Class&&)
) 也是隐式声明的,除非您声明复制或移动构造函数,或者复制或移动赋值运算符。

请注意,您的构造函数模板不是复制构造函数,并且将使用隐式构造函数:

Class<T1> t1;
Class<T1>(t1); // prints nothing
Class<T2>(t1); // prints "My copy constructor" (which is a lie)

根据标准,这种行为完全正常吗?

是的,请参阅第 12 章。

我是否可以保证不会自动添加空构造函数并且

Class<int> x;
会写
"My normal constructor"

是的,只有在您根本不声明任何构造函数时才会隐式声明默认构造函数。

© www.soinside.com 2019 - 2024. All rights reserved.