添加章节跳转链接和修改一些格式

This commit is contained in:
yankuangshi
2014-06-10 22:51:41 +02:00
parent 9af353f0fc
commit 8af7bf0bca

View File

@ -1,23 +1,25 @@
# 枚举 # 枚举Enumerations
----------------- -----------------
本页内容包含: 本页内容包含:
- 枚举语法 - 枚举语法Enumeration Syntax
- 匹配枚举值与`Swith`语句 - 匹配枚举值与`Switch`语句Matching Enumeration Values with a Switch Statement
- 关联值(associated values - 关联值(Associated values
- 原始值(raw values - 原始值(Raw values
枚举enumeration定义了一个通用类型的一组相关的值,使你可以在你的代码中以一个安全的方式来使用这些值。 **枚举**定义了一个通用类型的一组相关的值,使你可以在你的代码中以一个安全的方式来使用这些值。
如果你熟悉 C 语言,你就会知道,在 C 语言中枚举指定相关名称为一组整型值。Swift 中的枚举更加灵活不必给每一个枚举成员enumeration member提供一个值。如果一个值被认为是“原始”值被提供给每个枚举成员则该值可以是一个字符串一个字符或是一个整型值或浮点值。 如果你熟悉 C 语言,你就会知道,在 C 语言中枚举指定相关名称为一组整型值。Swift 中的枚举更加灵活不必给每一个枚举成员enumeration member提供一个值。如果一个值被认为是“原始”值被提供给每个枚举成员则该值可以是一个字符串一个字符或是一个整型值或浮点值。
此外枚举成员可以指定任何类型的关联值存储到枚举成员值中就像其他语言中的联合体unions和变体variants。你可以定义一组通用的相关成员作为枚举的一部分每一组都有不同的一组与它相关的适当类型的数值。 此外枚举成员可以指定任何类型的关联值存储到枚举成员值中就像其他语言中的联合体unions和变体variants。你可以定义一组通用的相关成员作为枚举的一部分每一组都有不同的一组与它相关的适当类型的数值。
在Swift中枚举类型是一等first-class类型。它们采用了很多传统上只被类class)所支持的特征例如计算型属性computed properties)用于提供关于枚举当前值的附加信息实例方法instance methods用于提供和枚举所代表的值相关联的功能。枚举也可以定义构造函数initializers来提供一个初始成员值可以在原始的实现基础上扩展它们的功能可以遵守协议protocols来提供标准的功能。 Swift 枚举类型是一等first-class类型。它们采用了很多传统上只被类所支持的特征例如计算型属性computed properties)用于提供关于枚举当前值的附加信息实例方法instance methods用于提供和枚举所代表的值相关联的功能。枚举也可以定义构造initializers来提供一个初始成员值可以在原始的实现基础上扩展它们的功能可以遵守协议protocols来提供标准的功能。
欲了解更多相关功能,请参见属性Properties方法Methods构造过程Initialization扩展Extensions和协议Protocols 欲了解更多相关功能,请参考[属性](../chapter2/10_Properties.html)[方法](../chapter2/11_Methodes.html)[构造过程](../chapter2/14_Initialization.html)[扩展](../chapter2/20_Extensions.html),和[协议](../chapter2/21_Protocols.html)
<a name="enumeration_syntax"></a>
## 枚举语法 ## 枚举语法
使用`enum`关键词并且把它们的整个定义放在一对大括号内: 使用`enum`关键词并且把它们的整个定义放在一对大括号内:
@ -26,6 +28,7 @@
// enumeration definition goes here // enumeration definition goes here
} }
以下是指南针四个方向的一个例子: 以下是指南针四个方向的一个例子:
enum CompassPoint { enum CompassPoint {
@ -38,7 +41,7 @@
一个枚举中被定义的值(例如 `North``South``East``West`)是枚举的***成员值***(或者***成员***)。`case`关键词表明新的一行成员值将被定义。 一个枚举中被定义的值(例如 `North``South``East``West`)是枚举的***成员值***(或者***成员***)。`case`关键词表明新的一行成员值将被定义。
> 注意: > 注意:
> 不像C和Objective-C一样Swift的枚举成员在被创建时不会被赋予一个默认的整数值。在上面的`CompassPoints`例子中,`North``South``East``West`不是隐式得等于`0``1``2`和`3`。相反的,这些不同的枚举成员在`CompassPoint`的一种显示定义中拥有各自不同的值。 不像 C 和 Objective-C 一样Swift 的枚举成员在被创建时不会被赋予一个默认的整数值。在上面的`CompassPoints`例子中,`North``South``East``West`不是隐式得等于`0``1``2``3`。相反的,这些不同的枚举成员在`CompassPoint`的一种显示定义中拥有各自不同的值。
多个成员值可以出现在同一行上,用逗号隔开: 多个成员值可以出现在同一行上,用逗号隔开:
@ -56,6 +59,8 @@
`directionToHead`的类型已知时,当设定它的值时,你可以不再写类型名。使用显示类型的枚举值可以让代码具有更好的可读性。 `directionToHead`的类型已知时,当设定它的值时,你可以不再写类型名。使用显示类型的枚举值可以让代码具有更好的可读性。
<a name="matching_enumeration_values_with_a_switch_statement"></a>
## 匹配枚举值和`Switch`语句 ## 匹配枚举值和`Switch`语句
你可以匹配单个枚举值和`switch`语句: 你可以匹配单个枚举值和`switch`语句:
@ -79,7 +84,7 @@
等等依次类推。 等等依次类推。
正如在控制流Control Flow中介绍,当考虑一个枚举的成员们时,一个`switch`语句必须全面。如果忽略了`.West`这种情况,上面那段代码将无法通过编译,因为它没有考虑到`CompassPoint`的全部成员。全面性的要求确保了枚举成员不会被意外遗漏。 正如在[控制流](../chapter2/05_Control_Flow.html)中介绍,当考虑一个枚举的成员们时,一个`switch`语句必须全面。如果忽略了`.West`这种情况,上面那段代码将无法通过编译,因为它没有考虑到`CompassPoint`的全部成员。全面性的要求确保了枚举成员不会被意外遗漏。
当不需要匹配每个枚举成员的时候,你可以提供一个默认`default`分支来涵盖所有未明确被提出的任何成员: 当不需要匹配每个枚举成员的时候,你可以提供一个默认`default`分支来涵盖所有未明确被提出的任何成员:
@ -92,6 +97,7 @@
} }
// prints "Mostly harmless” // prints "Mostly harmless”
<a name="associated_values"></a>
## 关联值Associated Values ## 关联值Associated Values
上一小节的例子演示了一个枚举的成员是如何被定义(分类)的。你可以为`Planet.Earth`设置一个常量或则变量,并且在之后查看这个值。然而,有时候会很有用如果能够把其他类型的关联值和成员值一起存储起来。这能让你随着成员值存储额外的自定义信息,并且当每次你在代码中利用该成员时允许这个信息产生变化。 上一小节的例子演示了一个枚举的成员是如何被定义(分类)的。你可以为`Planet.Earth`设置一个常量或则变量,并且在之后查看这个值。然而,有时候会很有用如果能够把其他类型的关联值和成员值一起存储起来。这能让你随着成员值存储额外的自定义信息,并且当每次你在代码中利用该成员时允许这个信息产生变化。
@ -133,7 +139,7 @@
这时,原始的`Barcode.UPCA`和其整数值被新的`Barcode.QRCode`和其字符串值所替代。条形码的常量和变量可以存储一个`.UPCA`或者一个`.QRCode`(连同它的关联值),但是在任何指定时间只能存储其中之一。 这时,原始的`Barcode.UPCA`和其整数值被新的`Barcode.QRCode`和其字符串值所替代。条形码的常量和变量可以存储一个`.UPCA`或者一个`.QRCode`(连同它的关联值),但是在任何指定时间只能存储其中之一。
像以前那样不同的条形码类型可以使用一个switch语句来检查然而这次关联值可以被提取作为switch语句的一部分。你可以在`switch`的case分支代码中提取每个关联值作为一个常量`let`前缀)或者作为一个变量(用`var`前缀)来使用: 像以前那样,不同的条形码类型可以使用一个`switch`语句来检查,然而这次关联值可以被提取作为`switch`语句的一部分。你可以在`switch`的case分支代码中提取每个关联值作为一个常量`let`前缀)或者作为一个变量(用`var`前缀)来使用:
switch productBarcode { switch productBarcode {
case .UPCA(let numberSystem, let identifier, let check): case .UPCA(let numberSystem, let identifier, let check):
@ -153,6 +159,7 @@
} }
// prints "QR code with value of ABCDEFGHIJKLMNOP." // prints "QR code with value of ABCDEFGHIJKLMNOP."
<a name="raw_values"></a>
## 原始值Raw Values ## 原始值Raw Values
在关联值小节的条形码例子中演示了一个枚举的成员如何声明它们存储不同类型的关联值。作为关联值的替代,枚举成员可以被默认值(称为原始值)预先填充,其中这些原始值具有相同的类型。 在关联值小节的条形码例子中演示了一个枚举的成员如何声明它们存储不同类型的关联值。作为关联值的替代,枚举成员可以被默认值(称为原始值)预先填充,其中这些原始值具有相同的类型。
@ -165,7 +172,7 @@
case CarriageReturn = "\r" case CarriageReturn = "\r"
} }
在这里,称为`ASCIIControlCharacter`的枚举的原始值类型被定义为字符型`Character`并被设置了一些比较常见的ASCII控制字符。字符值的描述请详见字符串和字符`Strings and Characters`部分 在这里,称为`ASCIIControlCharacter`的枚举的原始值类型被定义为字符型`Character`,并被设置了一些比较常见的 ASCII 控制字符。字符值的描述请详见[字符串和字符](../chapter2/03_Strings_and_Characters.html)章节
注意,原始值和关联值是不相同的。当你开始在你的代码中定义枚举的时候原始值是被预先填充的值,像上述三个 ASCII 码。对于一个特定的枚举成员,它的原始值始终是相同的。关联值是当你在创建一个基于枚举成员的新常量或变量时才会被设置,并且每次当你这么做得时候,它的值可以是不同的。 注意,原始值和关联值是不相同的。当你开始在你的代码中定义枚举的时候原始值是被预先填充的值,像上述三个 ASCII 码。对于一个特定的枚举成员,它的原始值始终是相同的。关联值是当你在创建一个基于枚举成员的新常量或变量时才会被设置,并且每次当你这么做得时候,它的值可以是不同的。