我已经很多年没有写c++了,现在我正试图重新开始写c++。然后我看到了这个,想过要放弃:

typedef enum TokenType
{
    blah1   = 0x00000000,
    blah2   = 0X01000000,
    blah3   = 0X02000000
} TokenType;

这是什么?为什么这里使用typedef关键字?为什么这个名称TokenType在这个声明中出现了两次?语义与此有何不同:

enum TokenType
{
    blah1 = 0x00000000,
    blah2=0x01000000,
    blah3=0x02000000
};

当前回答

“为什么”这个问题(令人惊讶的是,现有的答案忽略了这个老问题)的实际答案是,这个枚举声明可能位于一个头文件中,该头文件旨在作为C和c++代码进行交叉编译(即包含在C和c++实现文件中)。编写此类头文件的艺术依赖于作者选择在两种语言中具有适当兼容含义的语言特性的能力。

其他回答

hold dover from拖延;

在C语言中,以第一种方式声明枚举可以这样使用:

TokenType my_type;

如果你使用第二种风格,你将被迫像这样声明你的变量:

enum TokenType my_type;

正如其他人所提到的,这在c++中没有什么不同。我的猜测是,要么写这篇文章的人本质上是一个C程序员,要么你把C代码编译成c++。无论哪种方式,它都不会影响代码的行为。

这是C语言的传承,如果你

enum TokenType
{
    blah1   = 0x00000000,
    blah2   = 0X01000000,
    blah3   = 0X02000000
};

你必须使用它来做以下事情:

enum TokenType foo;

但如果你这样做:

typedef enum e_TokenType
{
    blah1   = 0x00000000,
    blah2   = 0X01000000,
    blah3   = 0X02000000
} TokenType;

你可以声明:

TokenType foo;

但在c++中,您只能使用前一个定义,并像在C类型定义中一样使用它。

你不需要这么做。在C(不是c++)中,您需要使用枚举Enumname来引用枚举类型的数据元素。为了简化它,您可以将其类型定义为单个名称数据类型。

typedef enum MyEnum { 
  //...
} MyEnum;

允许使用枚举参数的函数定义为

void f( MyEnum x )

而不是更长

void f( enum MyEnum x )

注意,typename的名称不需要等于enum的名称。结构体也是如此。

另一方面,在c++中,这不是必需的,因为枚举、类和结构可以通过它们的名称直接作为类型访问。

// C++
enum MyEnum {
   // ...
};
void f( MyEnum x ); // Correct C++, Error in C

“为什么”这个问题(令人惊讶的是,现有的答案忽略了这个老问题)的实际答案是,这个枚举声明可能位于一个头文件中,该头文件旨在作为C和c++代码进行交叉编译(即包含在C和c++实现文件中)。编写此类头文件的艺术依赖于作者选择在两种语言中具有适当兼容含义的语言特性的能力。