我不认为我从根本上理解枚举是什么,以及什么时候使用它。

例如:

typedef enum {
    kCircle,
    kRectangle,
    kOblateSpheroid
} ShapeType;

这里真正声明的是什么?


当前回答

枚举声明了一组有序值——typedef只是给它加了一个方便的名字。第一个元素是0等等。

typedef enum {
Monday=1,
...
} WORKDAYS;

WORKDAYS today = Monday;

上面只是shapeType标记的枚举。

其他回答

枚举声明了一组有序值——typedef只是给它加了一个方便的名字。第一个元素是0等等。

typedef enum {
Monday=1,
...
} WORKDAYS;

WORKDAYS today = Monday;

上面只是shapeType标记的枚举。

类型定义是C和c++中的关键字。它用于为基本数据类型(char, int, float, double, struct & enum)创建新名称。

typedef enum {
    kCircle,
    kRectangle,
    kOblateSpheroid
} ShapeType;

这里它创建枚举数据类型ShapeType &我们可以为枚举类型ShapeType写新的名称,如下所示

ShapeType shape1; 
ShapeType shape2; 
ShapeType shape3;

enum (enumeration的缩写)用于枚举一组值(枚举器)。值是由符号(词)表示的抽象事物。 例如,基本枚举可以是

enum { xs,s,m,l,xl,xxl,xxxl,xxxxl };

此枚举被称为匿名,因为您没有符号来命名它。但它仍然是完全正确的。就像这样用

enum { xs,s,m,l,xl,xxl,xxxl,xxxxl } myGrandMotherDressSize;

好的。生活是美丽的,一切都很顺利。但是有一天你需要重用这个枚举来定义一个新变量来存储myGrandFatherPantSize,然后你写:

enum { xs,s,m,l,xl,xxl,xxxl,xxxxl } myGrandMotherDressSize;
enum { xs,s,m,l,xl,xxl,xxxl,xxxxl } myGrandFatherPantSize;

但是你有一个编译器错误“重定义枚举器”。实际上,问题是编译器不确定你的第一个枚举和你的第二个枚举描述的是同一件事。

然后,如果您想在多个地方重用同一组枚举数(这里是xs…xxxxl),则必须使用唯一的名称标记它。第二次使用这个集合时,只需使用标签即可。但是不要忘记,这个标记并不替换枚举词,而只是一组枚举数。然后注意像往常一样使用enum。是这样的:

// Here the first use of my enum
enum sizes { xs,s,m,l,xl,xxl,xxxl,xxxxl } myGrandMotherDressSize; 
// here the second use of my enum. It works now!
enum sizes myGrandFatherPantSize;

你也可以在参数定义中使用它:

// Observe that here, I still use the enum
- (void) buyANewDressToMyGrandMother:(enum sizes)theSize;

可以说,在所有地方重写枚举并不方便,而且会使代码看起来有点奇怪。你说得对。真正的类型会更好。

这是我们向顶峰伟大前进的最后一步。通过添加typedef,我们可以将枚举转换为实类型。最后一点,typedef在类中是不允许的。然后在上面定义你的类型。这样做:

// enum definition
enum sizes { xs,s,m,l,xl,xxl,xxxl,xxxxl };
typedef enum sizes size_type

@interface myClass {
   ...
   size_type myGrandMotherDressSize, myGrandFatherPantSize;
   ...
}

记住,标记是可选的。在这种情况下,我们不标记枚举数,而只是定义一个新类型。那我们就不再需要它了。

// enum definition
typedef enum { xs,s,m,l,xl,xxl,xxxl,xxxxl } size_type;

@interface myClass : NSObject {
  ...
  size_type myGrandMotherDressSize, myGrandFatherPantSize;
  ...
}
@end

如果你在Objective-C中使用XCode开发,我会让你发现一些以NS_ENUM为前缀的宏。这将帮助您轻松地定义好的枚举,而且还将帮助静态分析器在编译之前为您做一些有趣的检查。

Enum好!

枚举可以减少许多类型的“错误”,并使代码更易于管理

#define STATE_GOOD 0
#define STATE_BAD 1
#define STATE_OTHER 2
int STATE = STATE_OTHER

这个定义没有约束。这只是一个简单的代换。 它不能限制国家的所有条件。当STATE被赋值为5时,程序将出错,因为没有匹配的状态。但是编译器不会警告STATE = 5

所以这样用比较好

typedef enum SampleState {
    SampleStateGood  = 0,
    SampleStateBad,
    SampleStateOther
} SampleState;

SampleState state = SampleStateGood;

64位更改的更新: 根据苹果关于64位变化的文档,

枚举也是类型化的:在LLVM编译器中,枚举类型可以 定义枚举的大小。这意味着一些枚举 类型的大小也可能比您期望的要大。的 和其他情况一样,解是对a不做任何假设 数据类型的大小。相反,将任何枚举值赋给变量 使用适当的数据类型

因此,如果您支持64位,则必须创建具有以下语法类型的enum。

typedef NS_ENUM(NSUInteger, ShapeType) {
    kCircle,
    kRectangle,
    kOblateSpheroid
};

or

typedef enum ShapeType : NSUInteger {
   kCircle,
   kRectangle,
   kOblateSpheroid
} ShapeType;

否则,它将导致警告隐式转换丢失整型精度:NSUInteger (aka 'unsigned long')到ShapeType

swift编程更新:

在swift中,有一个语法变化。

enum ControlButtonID: NSUInteger {
        case kCircle , kRectangle, kOblateSpheroid
    }