模板参数的 C++ 自动模板推导失败
c++ automatic template deduction fails for template argument
我想更好地理解为什么自动模板推导(使用g++ -std=c++17
编译时应用(在main()
的前三行有效,但在第四行失败。在不久的将来,它是否有可能被编译器接受?
template <typename P = void>
class A {
public:
void f1() {}
};
template<typename C>
void g() {}
int main() {
A<> a; // works
A aa; // works
g<A<>>(); // works
g<A>(); // fails
return 0;
}
这只是一个签名问题。基本上你传递了错误的类型。
A a
和A<> a
都意味着您需要一个具有默认模板参数值的A
实例,也就是说,您最终得到A< void >
.
函数g< C >()
接受模板参数,该参数恰好是一个类型,而不是另一个模板化类型。当你用A<>
调用它时,你告诉编译器你想使用模板化类型的"实例化"A
,这是有效的。当您使用A
调用它时,您告诉编译器您要调用g< C >()
C
是不符合其签名的模板化类型。
如果你像这样声明/定义g()
template <typename <typename> TTemplatedType> g()
它将接受像这样g< A >()
调用,但g< A<> >()
会失败,因为现在它不再需要模板化类型以外的其他东西。
对于 C++17,当类模板的名称用作正在构造的对象的类型时,也会执行模板参数推导。
模板中的显式类型没有任何变化。
相关文章:
- 如果没有malloc,链表实现将失败
- 模板参数替换失败,并且未完成隐式转换
- 具有默认模板参数的多态类的模板推导失败
- 视图中的参数推导失败:take_while
- 链接到自行创建的dll失败
- 带有特殊路径部分的"std::filesystem::weakly_canonical"失败
- GetShortPathName在网络驱动器上使用中文文件夹时失败
- gcc和c++17的过载解析失败
- 为什么使用 P/Invoke 调用 dll 时,某些计算机中的 LoadLibrary 失败?
- 在WSL:configure_file上对config_file的每次调用都失败:配置文件时出现问题
- 使用 GCC 卸载的 OpenMP 卸载失败,并出现"Ptx assembly aborted due to errors"
- 使用cmake从源代码构建MySQL连接器/C++失败(与以前的声明冲突)
- 链接阶段在Ubuntu上失败,但在MacOS上失败
- 从父数组测试用例构造二叉树失败
- LibGit2 SSH身份验证失败
- 如何让LLDB在成功时退出,在失败时等待
- VS2017,C++包含目录与附加包含目录,子文件夹包含失败-但为什么
- 生成MRPT库时cmake配置失败
- 为什么除非添加括号,否则构造函数上的模板替换会失败?
- variadic模板中的模板参数推导失败