如何在C ++中使用枚举作为标志?

如何在C ++中使用枚举作为标志?

enums作为标志处理可以在C#中通过[Flags]属性很好地工作,但是在C ++中执行此操作的最佳方法是什么?

例如,我想写:

enum AnimalFlags{
    HasClaws = 1,
    CanFly =2,
    EatsFish = 4,
    Endangered = 8};seahawk.flags = CanFly | EatsFish | Endangered;

但是,我收到关于intenum转换的编译器错误。是否有更好的表达方式而不仅仅是直接的铸造?优选地,我不想依赖来自第三方库的构造,例如boost或Qt。

编辑:如答案中所示,我可以通过声明seahawk.flags为避免编译器错误int。但是,我想有一些机制来强制执行类型安全,所以有人不能写seahawk.flags = HasMaximizeButton


梵蒂冈之花
浏览 535回答 3
3回答

波斯汪

“正确”的方法是为枚举定义位运算符,如:enum&nbsp;AnimalFlags{ &nbsp;&nbsp;&nbsp;&nbsp;HasClaws&nbsp;=&nbsp;1, &nbsp;&nbsp;&nbsp;&nbsp;CanFly&nbsp;=2, &nbsp;&nbsp;&nbsp;&nbsp;EatsFish&nbsp;=&nbsp;4, &nbsp;&nbsp;&nbsp;&nbsp;Endangered&nbsp;=&nbsp;8};inline&nbsp;AnimalFlags&nbsp;operator|(AnimalFlags&nbsp;a,&nbsp;AnimalFlags&nbsp;b){return&nbsp;static_cast<AnimalFlags>(static_cast<int>(a)&nbsp;|&nbsp;static_cast<int>(b));}等等其他位运算符。如果枚举范围超出int范围,则根据需要进行修改。

红颜莎娜

注意(也有点偏离主题):使用位移可以完成另一种制作唯一标志的方法。我,我自己,发现这更容易阅读。enum&nbsp;Flags{ &nbsp;&nbsp;&nbsp;&nbsp;A&nbsp;=&nbsp;1&nbsp;<<&nbsp;0,&nbsp;//&nbsp;binary&nbsp;0001 &nbsp;&nbsp;&nbsp;&nbsp;B&nbsp;=&nbsp;1&nbsp;<<&nbsp;1,&nbsp;//&nbsp;binary&nbsp;0010 &nbsp;&nbsp;&nbsp;&nbsp;C&nbsp;=&nbsp;1&nbsp;<<&nbsp;2,&nbsp;//&nbsp;binary&nbsp;0100 &nbsp;&nbsp;&nbsp;&nbsp;D&nbsp;=&nbsp;1&nbsp;<<&nbsp;3,&nbsp;//&nbsp;binary&nbsp;1000};它可以将值保持为int,因此在大多数情况下,32个标志清楚地反映在移位量中。

明月笑刀无情

对于像我这样的懒人,这里是复制和粘贴的模板化解决方案:template<class T> inline T operator~ (T a) { return (T)~(int)a; }template<class T> inline T operator| (T a, T b) { return (T)((int)a | (int)b); }template<class T> inline T operator& (T a, T b) { return (T)((int)a & (int)b); }template<class T> inline T operator^ (T a, T b) { return (T)((int)a ^ (int)b); }template<class T> inline T& operator|= (T& a, T b) { return (T&)((int&)a |= (int)b); }template<class T> inline T& operator&= (T& a, T b) { return (T&)((int&)a &= (int)b); }template<class T> inline T& operator^= (T& a, T b) { return (T&)((int&)a ^= (int)b); }
打开App,查看更多内容
随时随地看视频慕课网APP