C ++奇怪的构造函数行为

时间:2012-11-11 22:46:33

标签: c++ constructor stack destructor

有人可以向我解释复杂a; 复杂b(); 之间的区别吗?

#include<iostream>

class Complex
{
public:

    Complex()
    {
        std::cout << "Complex Constructor 1" << std::endl;
    }

    Complex(float re, float im)
    {
        std::cout << "Complex Constructor 2" << std::endl;
    }

    ~Complex()
    {
        std::cout << "Complex Destructor" << std::endl;
    }    
};

int main()
{
    Complex a;
    std::cout << "--------------------------" << std::endl;
    Complex b();
    std::cout << "--------------------------" << std::endl;
    Complex c(0,0);
    std::cout << "--------------------------" << std::endl;

    return 0;
}

输出:

Complex Constructor 1
--------------------------
--------------------------
Complex Constructor 2
--------------------------
Complex Destructor
Complex Destructor

如您所见,复杂a; 会调用其默认构造函数,复杂b(); 不会和复杂c(0,0) ; 调用重载的构造函数。

这里发生了什么?我想,复杂的b(); 会创建一个堆栈变量并调用它的默认构造函数来初始化它?

2 个答案:

答案 0 :(得分:8)

Complex b();是函数声明。这是没有参数并返回Complex对象的函数。

这是一个非常常见的错误,并有自己的名称:most vexing parse

C ++ 11通过引入uniform initialization syntax

帮助解决了这个问题
Complex b{};

答案 1 :(得分:4)

Complex b();声明一个没有参数的函数,并返回Complex