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...>{}; 现在这显然不会起作用,因为它实际上并不专门化这个类;但我不知道该怎么写而不是这个.我希望能够从已定义的带有标签的类派生,这样我就不必冗余地定义运算符和方法. 怎么能实现这一目标? 解决方法
事实上,不,它不是专业化而是正常情况,所以使用: template<typename ... Args> class event : event<callable_tag,Args...>{}; Live example (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |