首页 > 代码库 > 编译期间侦测可转换性

编译期间侦测可转换性

template <class T,class U>
class Conversion
{
    typedef char Small;
    class Big {char dummy[2]; };
    static Small Test(U);
    static Big Test(...);
    static T MakeT(); //稻草人函数
public:
    enum { exists = sizeof(Test(MakeT())) == sizeof(Small)};
};

int _tmain(int argc, _TCHAR* argv[])
{
    using namespace std;

    cout<< Conversion<double,int>::exists << ‘ ‘;
    
    getchar();

    return 0;
}

 

sizeof 并不会真有任何表达式被求值。

====================================

template <class T,class U>
class Conversion
{
    typedef char Small;
    class Big {char dummy[2]; };
    static Small Test(U);
    static Big Test(...);
    static T MakeT();
public:
    enum { exists = sizeof(Test(MakeT())) == sizeof(Small)};
    enum { exists2way = exists &&
        Conversion<U,T>::exists };
    enum { sameType = false};
};

template <class T>
class Conversion<T,T>
{
public:
    enum { exists = 1; exists2way =1; sameType = false};
};

class A
{
    int a;
};

class B :public A
{
    int a;
};

#define  SUPERSUBCLASS(T,U) \
    (Conversion<const U*,const T*>::exists && \
    !Conversion<const T*,void *>::sameType)

int _tmain(int argc, _TCHAR* argv[])
{
    using namespace std;

    cout<< Conversion<double,int>::exists << ‘ ‘;

    if( SUPERSUBCLASS(A,B) )
    {
        cout<< "SUPERSUBCLASS<A,B>,A is base class" << ‘ ‘;
    }
    
    getchar();

    return 0;
}

 

编译期间侦测可转换性