用于显式特化模板类中的模板函数的 C++ 语法?

时间:2023-02-23
本文介绍了用于显式特化模板类中的模板函数的 C++ 语法?的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着跟版网的小编来一起学习吧!

问题描述

我的代码在 VC9(Microsoft Visual C++ 2008 SP1)中有效,但在 GCC 4.2(Mac 上)中无效:

I have code which works in VC9 (Microsoft Visual C++ 2008 SP1) but not in GCC 4.2 (on Mac):

struct tag {};

template< typename T >
struct C
{   
    template< typename Tag >
    void f( T );                 // declaration only

    template<>
    inline void f< tag >( T ) {} // ERROR: explicit specialization in
};                               // non-namespace scope 'structC<T>'

我知道 GCC 希望我将我的显式专业化转移到课程之外,但我无法弄清楚语法.有什么想法吗?

I understand that GCC would like me to move my explicit specialization outside the class but I can't figure out the syntax. Any ideas?

// the following is not correct syntax, what is?
template< typename T >
template<>
inline void C< T >::f< tag >( T ) {}

推荐答案

如果不显式特化包含类,就不能特化成员函数.
但是,您可以做的是将调用转发到部分专用类型的成员函数:

You can't specialize a member function without explicitly specializing the containing class.
What you can do however is forward calls to a member function of a partially specialized type:

template<class T, class Tag>
struct helper {
    static void f(T);   
};

template<class T>
struct helper<T, tag1> {
    static void f(T) {}
};

template<class T>
struct C {
    // ...
    template<class Tag>
    void foo(T t) {
        helper<T, Tag>::f(t);
    }
};

这篇关于用于显式特化模板类中的模板函数的 C++ 语法?的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持跟版网!

上一篇:`is_base_of` 是如何工作的? 下一篇:C++静态成员初始化(模板乐趣里面)

相关文章

最新文章