Si consideri il seguente codice:Forzare un sovraccarico specifico quando template
#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;
}
Per impostazione predefinita, produrrà:
Version A
Version A
come forzare l'utilizzo del Version B
quando il tipo di passato è un modello template con la buona forma (posso aggiungere nuove versioni di f
, posso aggiungere std::enable_if
o altra sintassi dei caratteri di tipo C++ 11, ma se possibile vorrei evitare di aggiungere una classe helper)?