Swift回忆录-枚举

版权声明:本文为博主原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。
本文链接: https://blog.csdn.net/sdefzhpk/article/details/70139068

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, Int)
    case qrCode(String)
}

描述:定义了一个Barcode的枚举类型,有两个成员值 upcqrCode ; 其类型分别是(Int,Int,Int,Int)(String) 类型.

用法:

“`
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"
}

原始值的隐式赋值

在使用原始值为整数或者字符串类型的枚举时,不需要显式地为每一个枚举成员设置原始值,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

猜你喜欢

转载自blog.csdn.net/sdefzhpk/article/details/70139068