Forwarding all constructors in C++0x(在 C++0x 中转发所有构造函数)
问题描述
在 C++0x 中转发所有父级构造函数的正确方法是什么?
What is the correct way to forward all of the parent's constructors in C++0x?
我一直在这样做:
class X: public Super {
template<typename... Args>
X(Args&&... args): Super(args...) {}
};
推荐答案
C++0x 中有一个更好的方法来解决这个问题
There is a better way in C++0x for this
class X: public Super {
using Super::Super;
};
如果你声明一个完美转发模板,你的类型在重载解析中会表现得很糟糕.假设您的基类可以从 int 转换,并且有两个函数可以打印出类
If you declare a perfect-forwarding template, your type will behave badly in overload resolution. Imagine your base class is convertible from int and there exist two functions to print out classes
class Base {
public:
Base(int n);
};
class Specific: public Base {
public:
template<typename... Args>
Specific(Args&&... args);
};
void printOut(Specific const& b);
void printOut(std::string const& s);
你用
printOut("hello");
会叫什么?这是模棱两可的,因为 Specific 可以转换任何参数,包括字符数组.它这样做不考虑现有的基类构造函数.使用 using 声明继承构造函数仅声明使此工作所需的构造函数.
What will be called? It's ambiguous, because Specific can convert any argument, including character arrays. It does so without regard of existing base class constructors. Inheriting constructors with using declarations only declare the constructors that are needed to make this work.
这篇关于在 C++0x 中转发所有构造函数的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持编程学习网!
本文标题为:在 C++0x 中转发所有构造函数
基础教程推荐
- 非静态 const 成员,不能使用默认赋值运算符 2022-10-09
- 为什么 RegOpenKeyEx() 在 Vista 64 位上返回错误代码 2021-01-01
- 如果我为无符号变量分配负值会发生什么? 2022-01-01
- 为什么派生模板类不能访问基模板类的标识符? 2021-01-01
- 为什么 typeid.name() 使用 GCC 返回奇怪的字符以及如 2022-09-16
- 通过引用传递 C++ 迭代器有什么问题? 2022-01-01
- GDB 显示调用堆栈上函数地址的当前编译二进制文 2022-09-05
- CString 到 char* 2021-01-01
- 初始化列表*参数*评估顺序 2021-01-01
- 我应该对 C++ 中的成员变量和函数参数使用相同的名称吗? 2021-01-01
