C++ 11:我们何时需要为默认成员函数专门设置“= default”?
有没有一个简单的测试,结果发现,“=默认”只适用于特殊的成员函数,像这样:C++ 11:我们何时需要为默认成员函数专门设置“= default”?
#include<cstdio>
#include<utility>
struct Base{
Base(int){printf("Base(int)\n");}
};
struct Derived{
Derived(int)=default;
};
int main(){
Derived d(0);
return 0;
}
铛将报告编译错误:
error: only special member functions may be defaulted
因此,如果只有“特殊成员函数“是允许的,这个”= default“似乎没用:因为如果我没有在”派生“中给出特殊成员函数的定义,编译器会为我生成一个,等于使用”= default“。
所以我的问题是,为什么以及什么时候需要“=默认”?
because if I don't give definition of special member functions in "Derived", compiler will generate one for me, equal to using "=default".
因为有些情况下不会生成一些特殊的成员函数,例如,当你声明复制构造函数时,移动构造函数将不会被生成,然后移动请求将被复制构造函数处理。添加(默认)移动构造函数可以防止:
struct Derived {
Derived(const Derived&) { ... }
Derived(Derived&&) = default;
};
if I don't give definition of special member functions in "Derived", compiler will generate one for me, equal to using "=default".
不,实际上。
声明任何构造函数 - 并且编译器提供的默认构造函数将消失。要将其恢复(以编译器提供的形式),可以将其定义为= default
。
提供用户声明的析构函数 - 并且编译器提供的移动构造函数和移动赋值运算符将消失。为了让他们回来,你可以将它们定义为= default
。
提供用户声明的移动赋值运算符 - 并且编译器提供的复制构造函数和复制赋值运算符将消失。反正你懂这个意思。
= default
用于需要在特定成员函数的情况下以及其他情况导致该函数“消失”时带回编译器提供的特殊成员函数的功能。