在C++ 03中,可以通过将它放在类(或命名空间)中模仿strongly typed enum:
struct MyEnum
{
enum enumName
{
VALUE_1 = 1,
VALUE_2,
};
};
使用它:
MyEnum::enumName v = MyEnum::VALUE_1;
在C语言中有可能做类似的事情吗?如果是,怎么做?
我这样试过了,但没用:
struct A
{
enum aa
{
V1 = 5
};
};
int main()
{
A::aa a1 = A::V1;
enum A::aa a2 = A::V1;
struct A::aa a3 = A::V1;
return 0;
}
最佳答案
这是我的解决办法。与@eric的设计相比有几个优点:
支持相等测试(例如A_VALUE_0 == value
)
不依赖C99的复合文字
可以强制转换以将不正确的值分配给枚举。
缺点:
标志不起作用(例如A_VALUE_0 | A_VALUE_1
)
不能switch
'd
在测试相等性时,可能会混淆错误行所在的IDE(例如A_VALUE_0 == B_VALUE_1
)
笔记
永远不要取消引用这种类型的指针。会比兰博基尼更容易撞车
下面是实现(使用-Werror
&-pedantic
编译):
typedef struct A { char empty[1]; } *A; // we use 'empty' so that we don't get a warning that empty structs are a GNU extension
#define A_VALUE_0 ((A) 0x1)
#define A_VALUE_1 ((A) 0x2)
#define A_VALUE_2 ((A) 0x4)
typedef struct B { char empty[1]; } *B;
#define B_VALUE_0 ((B) 0x0)
#define B_VALUE_1 ((B) 0x1)
#define B_VALUE_2 ((B) 0x2)
int main()
{
A a = A_VALUE_0;
int equal = (a == A_VALUE_1); // works!
int euqal = (a == B_VALUE_1) // doesn't work
A flags = A_VALUE_0 | A_VALUE_1; // doesn't work!
switch (a) { // doesn't work
case A_VALUE_0:
puts("value 0");
break;
case A_VALUE_1:
puts("value 1");
break;
case A_VALUE_2:
puts("value 2");
break;
default:
puts("unknown value");
break;
} // doesn't work
// casting works for assignment:
A b = (A) (B_VALUE_2);
return 0;
}
关于c - 如何在C中模拟强类型枚举?,我们在Stack Overflow上找到一个类似的问题:https://stackoverflow.com/questions/11903625/