考虑以下代码:
#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 类型特征语法,但如果可能的话,我想避免添加帮助器班级) ?