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 – 任何顺序的多个标签的模板专业化所遇到的程序开发问题。
如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)