通过枚举重载模板化成员函数
Overloading a templated member function through enum
假设我有一个由READ
、WRITE
和SIGNAL
唯一枚举的EventHandle
类,并且我正在实现一个成员模板,该模板应该针对不同的枚举返回不同的数据类型。
enum class EventType {
READ,
WRITE,
SIGNAL
};
class EventHandle {
public:
template <EventType type, typename = enable_if_t<is_same<type, READ>::value>>
ReadEventHandle* cast () { return static_cast<ReadEventHandle>(this); }
template <EventType type, typename = enable_if_t<is_same<type, WRITE>::value>>
WriteEventHandle* cast () { return static_cast<WriteEventHandle>(this); }
template <EventType type, typename = enable_if_t<is_same<type, SIGNAL>::value>>
SignalEventHandle* cast () { return static_cast<SignalEventHandle>(this); }
};
我有三个从EventHandle
派生的类。
class ReadEventHandle : public EventHandle {...}
class WriteEventHandle : public EventHandle {...}
class SignalEventHandle : public EventHandle {...}
很明显,我写的东西无法编译。有没有任何方法可以在"编译"时实现这种类型的强制转换重载(例如,枚举上没有开关)?
一种具有某些特征和专业化的替代品:
enum class EventType {
READ,
WRITE,
SIGNAL
};
class ReadEventHandle;
class WriteEventHandle;
class SignalEventHandle;
template <EventType E> struct EventHandleType;
template <> struct EventHandleType<EventType::READ> { using type = ReadEventHandle; };
template <> struct EventHandleType<EventType::WRITE> { using type = WriteEventHandle; };
template <> struct EventHandleType<EventType::SIGNAL> { using type = SignalEventHandle; };
然后:
class EventHandle {
public:
template <EventType E>
typename EventHandleType<E>::type* cast();
};
template <EventType E>
typename EventHandleType<E>::type*
EventHandle::cast() { return static_cast<typename EventHandleType<E>::type*>(this); }
演示
我不能说我完全理解你想做什么,但你肯定没有正确使用SFINAE。以下是我希望可以作为指导的可编译代码:
#include <type_traits>
enum class EventType {
READ,
WRITE,
SIGNAL
};
class ReadEventHandle { };
class WriteEventHandle { };
class SignalEventHandle { };
ReadEventHandle re;
WriteEventHandle we;
SignalEventHandle se;
class EventHandle {
public:
template <EventType type, std::enable_if_t<type == EventType::READ>* = nullptr >
ReadEventHandle* cast () { return &re; }
template <EventType type, std::enable_if_t<type == EventType::WRITE>* = nullptr >
WriteEventHandle* cast () { return &we; }
template <EventType type, std::enable_if_t<type == EventType::SIGNAL>* = nullptr>
SignalEventHandle* cast () { return &se; }
};
void* check() {
return EventHandle().cast<EventType::READ>(); // Depending on cast argument, different pointers returned
}
相关文章:
- 对RValue对象调用的LValue ref限定成员函数
- 为什么使用 "this" 指针调用派生成员函数?
- 将公共但非静态的成员函数与ALGLIB集成
- 使用指向成员的指针将成员函数作为参数传递
- 将重载的成员函数传递给函数模板
- 我不小心调用了一个没有自己类对象的成员函数.但这是怎么回事呢
- 如何在C++中使用非静态成员函数作为回调函数
- C++错误C2600:无法定义编译器生成的特殊成员函数(必须首先在类中声明)
- 关联容器的下界复杂性:成员函数与非成员函数
- 在 C++ 中用派生类型重写成员函数
- 链表的泛型函数remove()与成员函数remove)
- 如何将lambda作为模板类的成员函数参数
- constexpr构造函数需要常量成员函数时出现问题
- 将自由函数绑定为类成员函数
- 区分非成员函数和头文件中的成员函数
- 如何从子成员函数修改父公共成员变量
- 保留对其他类的成员函数的引用
- 在运算符重载定义中使用成员函数(const错误)
- 内联如何影响模块接口中的成员函数
- 将成员函数指针作为参数传递给模板方法