Swift回忆录-枚举

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
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值