[英]Enum inside enum on C++
我试图基于常量来构建一个结构。 我有ObjectTypes
(KEYBOARD,MOUSE,HAPTIC ...),它可以有InputTypes
(MOUSE可以是DEFAULT和INVERSE,而KEYBOARD可以是DEFAULT,NUMERIC和HAPTIC只能是DEFAULT)。
为了实现这一点,我正在尝试在C ++中名为Constants
的类中使用枚举内部的枚举。 它可能会将ObjectTypes
参数和InputTypes
参数传递给函数,所以我需要在原型中使用这样的东西:
changeInputSystem(SimulatorConstants::InputObject input, SimulatorConstants::InputTypes type)
但是在C ++中,当我声明一个枚举时,从这个(内部)取出的每一个值都会取代其他值。
我现在的代码(而不是工作)是:
enum InputObject {
KEYBOARD,
MOUSE,
HAPTIC
};
enum InputTypes {
enum KeyboardTypes {
DEFAULT
};
enum MouseTypes {
DEFAULT,
INVERSE
};
enum HapticTypes {
DEFAULT
};
};
注意:我知道枚举之间没有继承,所以我需要任何可以以类似方式工作的解决方案。 谢谢。
如果您完成面向对象的整个过程,它就可以工作。 因此,不要让所有内容的枚举只有类:
class InputObject {};
class Mouse : public InputObject
{
void setDefault();
void setInverse();
};
这样,InputObject的类型可以保存在对象中,并且只传递实际的InputObject。
就像在评论中写的那样,如果你有权访问C ++ 11编译器,最好使用枚举类,这会将你自己接受的答案(在撰写本文时)改为:
enum class KeyboardTypes {
DEFAULT
};
enum class MouseTypes {
DEFAULT,
INVERSE
};
enum class HapticTypes {
DEFAULT
};
当然,您的重载函数可以更改为更自然的版本:
void changeInputSystem(SimulatorConstants::MouseTypes type);
void changeInputSystem(SimulatorConstants::KeyboardTypes type);
void changeInputSystem(SimulatorConstants::HapticTypes type);
并且,作为奖励,您的枚举不会隐式转换为整数值。
好吧,做一些证明我终于使用重载解决了它。 我通过重载方法并创建三个不同的结构来删除ObjectTypes:
struct KeyboardTypes {
enum types{
DEFAULT
};
};
struct MouseTypes {
enum types{
DEFAULT,
INVERSE
};
};
struct HapticTypes {
enum types{
DEFAULT
};
};
并且重载的成员函数:
void changeInputSystem(SimulatorConstants::MouseTypes::types type);
void changeInputSystem(SimulatorConstants::KeyboardTypes::types type);
void changeInputSystem(SimulatorConstants::HapticTypes::types type);
感谢所有帮助过的人。
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.