2

我的项目有问题,这是一些测试代码,在项目中看起来一样。有些类是普通的,但其中之一是具有 2 种不同类型(B 类)的模板类,例如 int 和 double。

class Bar
{
    Bar()
    {
    }
};

template< typename _T >
class B
{
    B();
};

template< typename _T >
B<_T>::B()
{
}

typedef B<int> Bint;
typedef B<double> Bdouble;

template< typename _T >
class Test
{
    Test();
    void method();
};

template< typename _T >
Test<_T>::Test()
{
}

template< typename _T >
void
Test<_T>::method()
{
}

template< >
void
Test< Bar >::method()
{
   //do sth for Bar
}

我知道我可以通过 spcializingB<int>B<double>for 模板参数来做到这一点,但它会使代码加倍。这是一个问题,我只想为模板 B 类专门化方法,有什么办法吗?我知道这段代码行不通:

template< >
void
Test< B< _T> >::method()
{
   ////do sth for B< _T >
}
4

1 回答 1

3

解决方案有点复杂,请看内联注释以获得一些解释

class Bar
{
    Bar() {}
};

template< typename T >
class B
{
    B() {}
};

typedef B<int> Bint;
typedef B<double> Bdouble;

template< typename T >
class Test
{
    Test() {}

private:
    // you need one level of indirection
    template<typename U> struct method_impl
    {
        static void apply();
    };
    // declare a partial specialization
    template<typename X> struct method_impl< B<X> >
    {
        static void apply();
    };

public:
    // forward call to the above
    void method() { method_impl<T>::apply(); }
};

// and now you can implement the methods
template< typename T >
template< typename U >
void
Test<T>::method_impl<U>::apply()
{
    // generic implementation
}

template<>
template<>
void
Test< Bar >::method_impl<Bar>::apply()
{
    //do sth for Bar
}

template< typename T >
template< typename X >
void
Test< T >::method_impl< B<X> >::apply()
{
    //do sth for B<X>
}
于 2013-09-17T07:56:45.387 回答