模板空括号初始化扣除
Template empty bracket initialization deduction
本文关键字:初始化 更新时间:2023-10-16
我认为模板函数可以有默认参数参数(不是模板参数,而是运行时参数)。我们还可以使用空括号初始化来初始化一个类。但是编译器如何匹配模板?
为什么编译这段代码,编译器如何进行推导,以及这个函数调用示例中的参数是什么?
我所了解的: 默认括号初始化调用空构造函数,该构造函数是隐式创建的,因为没有用户定义的构造函数或用户定义的默认构造函数。也就是说,我们可以用 {} 初始化任何包。所以扣除额在那里不适用,因为我们不能选择一个包,每个包都是候选的。也许默认的可变参数模板参数是<>(没有参数)。
template<typename...> class pack {};
template<class... Args>
inline auto make(pack<Args...> = {}) {
}
int main() { make(); }
(与海湾合作委员会编译) 注意:我认为不是,但默认参数可能很有用:调用函数的 2 种方法:make <int、char、int>()(正常使用)或 make(myPack) 来打包可变变量。
给定make();
,推导的Args
为空; 在这种情况下,make();
与make<>();
具有相同的效果。
模板参数是一个参数包,此处不提供模板参数。请注意,函数默认参数不参与模板参数推导。然后Args
被推断为空。
如果参数包显示为最后一个 P,则类型 P 将与调用中剩余每个参数的类型 A 匹配。每个匹配都会推断出包扩展中下一个位置的模板参数:
类型模板参数不能从函数默认参数的类型推导出来:
相关文章:
- 是否可以初始化不可复制类型的成员变量(或基类)
- C++使用整数的压缩数组初始化对象
- C++初始化基类
- 多成员Constexpr结构初始化
- 复制列表初始化的隐式转换的等级是多少
- 内联映射初始化的动态atexit析构函数崩溃
- 如何在C++中初始化嵌套类中的2个memeber
- 如何声明特征矩阵,然后通过嵌套循环初始化它
- 没有用于初始化C++中的变量模板的匹配构造函数
- 在未初始化映射的情况下,将值插入到映射的映射中
- C++成员初始化
- 为什么在C++中首先初始化成员类
- 同时具有"聚合初始化"和"模板推导"
- 初始化具有非默认构造函数的std::数组项的更好方法
- 是否可以在编译时初始化数组,以便在运行时不会花费时间?
- 我可以使用条件运算符初始化C风格的字符串文字吗
- 在C和C++中初始化结构中的数组
- 标准是否使用多余的大括号(例如 T{{{10}}})定义列表初始化?
- 在函数内部的声明中初始化数组,并在外部使用它
- 继承:构造函数,初始化C++11中基类的类C数组成员