构造函数而不是模板中的c++参数包规范
c++ parameter pack specification in constructor rather than template
与带有参数包的函数声明不同,我发现类需要尖括号中每个参数的类型。。。
Component<IntegerPair, int, int> temp(40, 5);
这似乎是多余的。以下是我如何定义Component
:
template<typename T, class... T_Args>
class Component
{
public:
Component(T_Args... args)
: m_data(args...)
{}
T m_data;
};
- 有没有办法从上述语句中删除
int, int
- 如果是,是否可以删除它
- 另外,我实例化
m_data
的方式安全吗?使用时std::forward<T_Args>(args)...
我的编译器告诉我我没有构造函数,该构造函数可以转换所有参数类型
一种方法是使构造函数成为模板:
#include <utility>
struct IntegerPair {
IntegerPair(int, int) {}
};
template<typename T>
class Component
{
public:
template<typename... T_Args>
Component(T_Args&&... args)
: m_data(std::forward<T_Args>(args)...)
{}
T m_data;
};
int main()
{
Component<IntegerPair> c {1,2};
}
这在功能上等价于std::vector
及其成员函数emplace_back
。这很好,IMO。错误消息非常神秘,就像在这样的模板结构中一样,但这可以通过适当的static_assert
来缓解。
模板参数推导仅适用于函数调用,因此实现所需功能的基本模式如下:
template<typename T, class... T_Args>
Component<T, T_Args...> makeComponent(T_Args&&... args) {
return Component<T, T_Args...>(std::forward<T_Args>(args)...);
}
用法:
auto c = makeComponent<IntegerPair>(1, 1)
相关文章:
- 如何反转整数参数包
- 使用C++库在Android项目中修改gradle中的cmake参数,用于插入指令的测试
- 如何使用默认参数等选择模板专业化
- 模板参数替换失败,并且未完成隐式转换
- 具有默认模板参数的多态类的模板推导失败
- lambda参数转换为constexpr技巧,然后获取带链接的数组
- 将数组作为参数传递给函数安全吗?作为第三方职能部门,可以探索他们想要的之外的其他元素
- 函数调用中参数的顺序重要吗
- 部分定义/别名模板模板参数
- 模板-模板参数推导:三个不同的编译器三种不同的行为
- 使用不带参数的函数访问结构元素
- 基于另一个成员参数将函数调用从类传递给它的一个成员
- 如何在OMNET++中指定与命令行参数组合的输出文件名
- 如何使用Luacneneneba API正确读取字符串和表参数
- 在派生函数中指定void*参数
- 视图中的参数推导失败:take_while
- static_assert在宏中,但也可以扩展到可以用作函数参数的东西
- 使用指向成员的指针将成员函数作为参数传递
- 没有名称的C++模板参数
- 如何将enable-if与模板参数和参数包一起使用