开发环境:VS2005(VC8)
以下代码在VS2002上运行不了,据说VS2002(VC7)不完全支持偏特化,VS2003(VC7.1)就支持了。
问题提出:
一,已知类型T,U,在编译阶段如何知道T能否转化成U。
template <class T, class U>
struct ConversionHelper
{
static long Test(...);//WQ注:C++中,不定参数已不需要“至少一个定参”了。
static short Test(U);
static T MakeT();
};
template <class T, class U>
struct Conversion
{
typedef ConversionHelper<T, U> H;
enum { exists = sizeof(short) == sizeof(H::Test(H::MakeT())) };
};
class A
{
public:
A()
{
TRACE("\r\nAr\n");
}
};
class B : public A
{
public:
B()
{
TRACE("\r\nBr\r\n");
}
};
测试代码:
bool b1 = Conversion<B,A>::exists;
bool b2 = Conversion<A,B>::exists;
运行结果分别为true,false.
二,接上面的问题。如果T能转化成U,则定义一个U类型的对象,否则定义T类型的变量。
template <int flag, typename T, typename U>
struct Select
{
typedef U Result;
};
template <typename T, typename U>
struct Select<0, T, U>
{
typedef T Result;
};
测试代码:
Select<Conversion<B,A>::exists,B,A>::Result type;
type的类型是A;B不再继承与A,则type类型是B。