Swift回忆录-枚举
特性
语法
enum SomeEnumeration {
// 枚举定义放在这里
}
例子
enum CompassPoint {
case north
case south
case east
case west
}
备注:Swift 的枚举成员在被创建时不会被赋予一个默认的整型值.
例子中,north,south,east和west不会被隐式地赋值为0,1,2和3
var directionToHead = CompassPoint.west
当 directionToHead 类型被推断出来后,后续在为directionToHead进行赋值可以使用简短的点语法
directionToHead = .east
关联值
可以定义 Swift 枚举来存储任意类型的关联值,甚至可以根据需求让每个枚举成员的关联值类型各不相同
例:定义一个有两种类型条形码枚举
enum Barcode {
case upc(Int,Int,Int)
case qrCode(String)
}
描述:定义了一个Barcode的枚举类型,有两个成员值
upc@H_404_94@ 、
qrCode@H_404_94@ ; 其类型分别是
(Int,Int,Int,Int)@H_404_94@ 、
(String)@H_404_94@ 类型.
用法:
“`
var productBarcode = Barcode.upc(8,85909,51226,3)
//还可以继续为productBarcode赋值不同类型的成员值
productBarcode = .qrCode(“ABCDEFGHIJKLMNOP”)
“`
原始值
在Swift中可以为枚举成员预设默认值(称为原始值)
例:使用 ASCII 码作为原始值的枚举
enum ASCIIControlCharacter: Character {
case tab = "\t"
case lineFeed = "\n"
case carriageReturn = "\r"
}
原始值的隐式赋值
在使用原始值为整数@H_404_94@或者
字符串类型@H_404_94@的枚举时,不需要显式地为每一个枚举成员设置原始值,Swift 将会自动为你赋值。
例如:当使用整数作为原始值时,隐式赋值的值依次递增1。如果第一个枚举成员没有设置原始值,其原始值将为0
例 1:
enum Planet: Int {
case mercury = 1,venus,earth,mars,jupiter,saturn,uranus,neptune
}
在上面的例子中,Plant.mercury的显式原始值为1,Planet.venus的隐式原始值为2,依次类推。
例 2:
enum CompassPoint: String {
case north,south,east,west
}
上面例子中,CompassPoint.south拥有隐式原始值south,依次类推
rawValue属性:
let earthsOrder = Planet.earth.rawValue
// earthsOrder 值为 3
let sunsetDirection = CompassPoint.west.rawValue
// sunsetDirection 值为 "west"
初始化枚举实例
如果在定义枚举类型的时候使用了原始值,那么将会自动获得一个初始化方法,这个方法接收一个叫做rawValue的参数,参数类型即为原始值类型,返回值则是枚举成员或nil
例:
let possiblePlanet = Planet(rawValue: 7)
// possiblePlanet 类型为 Planet? 值为 Planet.uranus