有没有办法创建一个类似于基本类型之一的新类型(例如 char),并且可以在两者之间进行隐式转换,但会在模板中以不同的方式解析,例如,以下代码可以工作?
typedef char utf8;
template<typename T>void f(T c);
template<> void f<char>(char c)
{
std::cout << "ascii " << c << std::endl;
}
template<> void f<utf8>(utf8 c)//error C2766: explicit specialization; 'void f<char>(char)' has already been defined
{
std::cout << "utf8 " << c << std::endl;
}
int main()
{
char c1 = 'x';
utf8 c2 = 'g';
f(c1);
f(c2);
}
我在想一个包含单个数据成员的类可能是可能的,如果是这样的话,最干净的方法是什么,编译器是否能够像它是一个原语一样优化它。
编辑:我尝试了 BOOST_STRONG_TYPEDEF,这似乎适用于基本的东西,但是我怎样才能继续从新类型创建 std::basic_string 呢?
BOOST_STRONG_TYPEDEF(char,utf8);
//first try
BOOST_STRONG_TYPEDEF(std::string,utf8_string);
//second try
typedef std::basic_string<utf8, std::char_traits<utf8>,std::allocator<utf8> > uft8_string;
第一个并没有真正起作用,因为生成的类型仍然需要 char 为其所有方法,而第二个似乎不喜欢构造函数和赋值运算符的存在:(
我还没有尝试过其他方法来创建新的 char 类型,如果我不能使用 BOOST_STRONG_TYPEDEF 是否能够解决这个问题?