在模板模板时强制特定重载
Force a specific overload when template template
本文关键字:重载 更新时间:2023-10-16
考虑以下代码:
#include <iostream>
#include <vector>
#include <type_traits>
// Version A
template<typename T>
void f(const T& x)
{
std::cout<<"Version A"<<std::endl;
}
// Version B
template<template<typename> class T, typename T1>
void f(const T<T1>& x)
{
std::cout<<"Version B"<<std::endl;
}
// Main
int main(int argc, char* argv[])
{
f(double());
f(std::vector<double>()); // <- How to force the use of version B ?
return 0;
}
默认情况下,它将产生:
Version A
Version A
当传递的类型是形状良好的模板模板时,如何强制使用Version B
(我可以添加新版本的f
,我可以添加std::enable_if
或其他C++11类型特征语法,但如果可能的话,我想避免添加帮助类)?
std::vector
不需要单个typename
参数,而是需要 2!不要忘记分配器。
因此,使用可变参数模板:
template<template<typename...> class T, typename T1>
void f(const T<T1>& x)
{
std::cout<<"Version B"<<std::endl;
}
现在它可以随心所欲地工作。
正如 Pubby 在他的回答中所解释的那样,std::vector 是一个具有两个参数的模板,因此您的重载函数需要采用更多的模板参数。如果您不想使用可变参数模板,则需要设置正确的参数数量:
#include <iostream>
#include <vector>
#include <type_traits>
// Version A
template<typename T>
void f(const T& )
{
std::cout<<"Version A"<<std::endl;
}
// Version B
template<template<typename,typename> class T, typename T1,typename T2>
void f(const T<T1,T2>& )
{
std::cout<<"Version B"<<std::endl;
}
template<typename T>
void baa(const T&)
{
}
// Main
int main()
{
f( double() );
f( std::vector<double>() ); // <- How to force the use of version B ?
}
相关文章:
- 继承函数的重载解析
- 你能重载对象变量名本身返回的内容吗
- 从父命名空间重载类型
- 使用C++中的模板和运算符重载执行矩阵运算
- 为什么这个运算符<重载函数对 STL 算法不可见?
- 重载操作程序时出错>>用于类中的字符串 memebr
- 一个关于在C++中重载布尔运算符的问题
- 不同翻译单元中不可重载的非内联函数定义
- 为什么使用SFINAE而不是函数重载
- 为什么我不能在 C++ 中的特定函数重载中调用同一函数的任何其他重载?
- 将重载的成员函数传递给函数模板
- c++:可变模板和函数重载
- 重载元组索引运算符-C++
- 如何使用重载的相等(==)运算符向测试用例添加描述
- 重载==不适用于二进制树
- 为什么Mat类的两个对象可以在不重载运算符+的情况下添加
- 重载运算符new[]的行为取决于析构函数
- 正在尝试重载二进制搜索树分配运算符
- 重载Singly Linked List中的赋值运算符
- 取消引用运算符不能重载