参考资料:SwiftGG
常规枚举
enum CompassPoint {
case north
case south
case east
case west
}
//或者这样写
enum Planet {
case mercury, venus, earth, mars, jupiter, saturn, uranus, neptune
}
//创建
var directionToHead = CompassPoint.west
//修改
directionToHead = .east
注意:Swift 的枚举成员在被创建时不会被赋予一个默认的整型值。在上面的 CompassPoint 例子中,north,south,east 和 west 不会被隐式地赋值为 0,1,2 和 3
CaseIterable 协议
令枚举遵循 CaseIterable 协议。Swift 会生成一个 allCases 属性,用于表示一个包含枚举所有成员的集合
enum Beverage: CaseIterable {
case coffee, tea, juice
}
let numberOfChoices = Beverage.allCases.count
print("\(numberOfChoices) beverages available")
// 打印“3 beverages available”
关联值
enum Barcode {
case upc(Int, Int, Int, Int)
case qrCode(String)
}
//创建
var productBarcode = Barcode.upc(8, 85909, 51226, 3)
//修改
productBarcode = .qrCode("ABCDEFGHIJKLMNOP")
注意:Barcode 类型的常量和变量可以存储一个 .upc 或者一个 .qrCode(连同它们的关联值),但是在同一时间只能存储这两个值中的一个
。
可以在 switch 的 case 分支代码中提取每个关联值作为一个常量(用 let 前缀)或者作为一个变量(用 var 前缀)来使用:
switch productBarcode {
case .upc(let numberSystem, let manufacturer, let product, let check):
print("UPC: \(numberSystem), \(manufacturer), \(product), \(check).")
case .qrCode(let productCode):
print("QR code: \(productCode).")
}
// 打印“QR code: ABCDEFGHIJKLMNOP.”
//如果一个枚举成员的所有关联值都被提取为常量,或者都被提取为变量,
//为了简洁,你可以只在成员名称前标注一个 let 或者 var:
witch productBarcode {
case let .upc(numberSystem, manufacturer, product, check):
print("UPC: \(numberSystem), \(manufacturer), \(product), \(check).")
case let .qrCode(productCode):
print("QR code: \(productCode).")
}
// 打印“QR code: ABCDEFGHIJKLMNOP.”
原始值
原始值可以是字符串、字符,或者任意整型值或浮点型值。每个原始值在枚举声明中必须是唯一的。
枚举在名字后加上原始值类型ASCIIControlCharacter: Character
的Character
enum ASCIIControlCharacter: Character {
case tab = "\t"
case lineFeed = "\n"
case carriageReturn = "\r"
}
原始值的隐式赋值
//会按顺序依次赋值 1-8
enum Planet: Int {
case mercury = 1, venus, earth, mars, jupiter, saturn, uranus, neptune
}
//原始值默认就是枚举名
enum CompassPoint: String {
case north, south, east, west
}
//这个例子利用原始值 7 创建了枚举成员 Uranus:
//返回的是可选类型
let possiblePlanet = Planet(rawValue: 7)
//如果你试图寻找一个位置为 11 的行星,通过原始值构造器返回的可选 Planet 值将是 nil: