加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 百科 > 正文

c – 任何顺序的多个标签的模板专业化

发布时间:2020-12-16 07:09:50 所属栏目:百科 来源:网络整理
导读:假设我有一个类event_base定义如此 templatetypename ... Argsclass event_base{ public: using delegate_type = std::functionvoid(Args...); using id_type = size_t; protected: std::vectorstd::tupledelegate_type,id_type m_funcs;}; 以及像这样定义的
假设我有一个类event_base定义如此

template<typename ... Args>
class event_base{
    public:
        using delegate_type = std::function<void(Args...)>;
        using id_type = size_t;

    protected:
        std::vector<std::tuple<delegate_type,id_type>> m_funcs;
};

以及像这样定义的几个空标记结构

struct mutable_tag{};
struct callable_tag{};

然后,我希望能够基于模板包中给出的标记中的任一个(或两个)从该基类派生

对于单个标签:

template<class ...>
class event;

template<typename ... Args>
class event<mutable_tag,Args...>: public event_base<Args...>{};

template<typename ... Args>
class event<callable_tag,Args...>: public event_base<Args...>{};

然后是多个标签:

template<typename ... Args>
class event<mutable_tag,callable_tag,Args...>: public event<mutable_tag,Args...>,public event<callable_tag,Args...>{};

template<typename ... Args>
class event<callable_tag,mutable_tag,Args...>{};

现在我希望能够在没有指定标签时专门化该类

例如:

template<typename ... Args>
class event<Args...>: event<callable_tag,Args...>{};

现在这显然不会起作用,因为它实际上并不专门化这个类;但我不知道该怎么写而不是这个.我希望能够从已定义的带有标签的类派生,这样我就不必冗余地定义运算符和方法.

怎么能实现这一目标?

解决方法

Now I want to be able to specialize the class for when no tags are specified

事实上,不,它不是专业化而是正常情况,所以使用:

template<typename ... Args>
class event : event<callable_tag,Args...>{};

Live example

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读