在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/

10-14 14:36