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

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

概述假设我有一个类event_base定义如此 template<typename ... Args>class event_base{ public: using delegate_type = std::function<void(Args...)>; using id_type = size_t; protected: std: 假设我有一个类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

总结

以上是内存溢出为你收集整理的c – 任何顺序的多个标签的模板专业化全部内容,希望文章能够帮你解决c – 任何顺序的多个标签的模板专业化所遇到的程序开发问题。

如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。

欢迎分享,转载请注明来源:内存溢出

原文地址: https://outofmemory.cn/langs/1227404.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2022-06-05
下一篇 2022-06-05

发表评论

登录后才能评论

评论列表(0条)

保存