template<typename T>
void trace(const T obj, bool newline = true);// #1
template<>
void trace<const stringstream*>(const stringstream* obj, bool newline);// #2
template<>
void trace<string*>(string* obj, bool newline);// #3
template<>
void trace<const char*>(const char* obj, bool newline);// #4
下面这段调用
stringstream ss0;
ss0 << 100;
trace(&ss0);//我发现在这里匹配的是#2
const stringstream ss1;
ss1 << 100;
trace(&ss1);//我发现在这里匹配的是#1
这意味着,假如这个模板函数要提供给别人使用,真对const stringstream* 和 stringstream* 我需要具体化两个模板函数。
template<>
void trace<const stringstream*>(const stringstream* obj, bool newline);//给const stringstream *使用
template<>
void trace<stringstream*>(stringstream* obj, bool newline);//给stringstream *使用
真心觉得好麻烦啊。有什么方法可以一个模板具体化搞定吗?
谢谢各位高人了!
模板 具体化 c c++
------解决方案--------------------------------------------------------
特化没办法,不过可以用重载。
template <typename T>
typename
std::enable_if<std::is_same<std::stringstream,
typename std::remove_const<T>::type
>::value
>::type
trace (T*const, bool = true); // #2
话说回来,通常情况下,const 和 non-const 类型的实现方法也不一样。你的例子如果是这样的话,接口统一就没法实现,因为内部处理的逻辑不一样的话,还是要想办法分开的。
------解决方案--------------------------------------------------------
#include <iostream>
#include <sstream>
#include <string>
template<typename T>
void trace(const T obj, bool newline = true)// #1
{
std::cout<< "#1";
}
template<>
void trace<const std::stringstream*>(const std::stringstream* obj, bool newline)
{
std::cout<< "#2";
}
template<>
void trace<std::string*>(std::string* obj, bool newline)
{
std::cout<< "#3";
}
template<>
void trace<const char*>(const char* obj, bool newline)
{
std::cout<< "#4";
}
int main()
{
std::stringstream ss0;
ss0 << 100;
trace(&ss0);
const std::stringstream ss1;
//ss1 << 100;
trace(&ss1);
return 0;
}
gcc 4.6.2运行结果: