只有当没有构造函数或声明了缺省构造函数时,我们才能不指定实参数集来定义类对象。...尤其是,如果一个类声明了一个包含多个参数的构造函数,但没有声明缺省构造函数,则每个类对象的定义都必须提供所需的实参。
class MyClass
{
public:
MyClass(int i, char ch): m_num(i), m_key('h') {}
void display(){ cout << m_num << " " << m_key << endl;}
private:
int m_num;
char m_key;
};
int main()
{
MyClass myclass;
myclass.display();
}
上述代码编译时会出现“no appropriate default constructor available”的错误。如果去掉双参数构造函数
MyClass(int i, char ch): m_num(i), m_key('h') {}
或者添加缺省构造函数:
或MyClass(): m_num(i), m_key('h') {}
编译错误都会消失。MyClass(int i = 0, char ch = 'h'): m_num(i), m_key('h') {}
在实践中,如果定义了其他构造函数,则也有必要提供一个缺省构造函数。...因为容器类(比如vector)要求他们的类元素或者提供缺省的构造函数,或者不提供构造函数。类似的,对于类对象的动态数组,在分配内存的时候也要求或者有缺省构造函数,或者没有构造函数。
缺省构造函数:
”缺省构造函数是指不需要用户指定实参就能够被调用的构造函数,这并不意味着它不能接受实参。只意味着构造函数的每个参数都有一个缺省值与之关联。比如:
Account::Account(){...} iStack::iStack(int size =0){...}
当我们写:
int main() { Accont acct; ... }
编译器首先检查Account类是否定义了缺省构造函数。以下情况之一会发生:
1. 定义了缺省构造函数,它被应用到acc上。
2. 定义了缺省构造函数,但它不是公有的。acct的定义被标记为编译时刻错误:main()没有访问权限。
3. 没有定义缺省构造函数,但是定义了一个或者多个要求实参的构造函数。acct的定义被标记为编译时刻错误:实参太少。
4. 没有定义缺省构造函数,也没有定义其他构造函数。该定义是合法的。acct没有被初始化,没有调用任何构造函数。
新用户常常会错误的认为,如果不存在缺省构造函数,则编译器会自动生成一个缺省构造函数,并将其应用在对象上,以初始化类的数据成员。对于我们定义的Account类(没有定义缺省构造函数,也没有定义其他构造函数)来说,这就不是真的:系统既没有生成缺省构造函数也没有调用它。对于含有类数据成员或继承来的比较复杂的类,这在部分上是对的;可能会生成一个缺省构造函数,但是它不会为内置或复合型的数据成员(如指针或数组)提供初始值。“