update new contents
This commit is contained in:
@ -46,7 +46,7 @@
|
||||
|
||||
|
||||
|
||||
<div class="book" data-level="1.1" data-basepath=".." data-revision="1402402017737">
|
||||
<div class="book" data-level="1.1" data-basepath=".." data-revision="1402440614492">
|
||||
<div class="book-header">
|
||||
<!-- Actions Left -->
|
||||
<a href="#" class="btn pull-left toggle-summary" aria-label="Toggle summary"><i class="fa fa-align-justify"></i></a>
|
||||
|
||||
@ -46,7 +46,7 @@
|
||||
|
||||
|
||||
|
||||
<div class="book" data-level="1.2" data-basepath=".." data-revision="1402402017737">
|
||||
<div class="book" data-level="1.2" data-basepath=".." data-revision="1402440614492">
|
||||
<div class="book-header">
|
||||
<!-- Actions Left -->
|
||||
<a href="#" class="btn pull-left toggle-summary" aria-label="Toggle summary"><i class="fa fa-align-justify"></i></a>
|
||||
|
||||
@ -46,7 +46,7 @@
|
||||
|
||||
|
||||
|
||||
<div class="book" data-level="1" data-basepath=".." data-revision="1402402017737">
|
||||
<div class="book" data-level="1" data-basepath=".." data-revision="1402440614492">
|
||||
<div class="book-header">
|
||||
<!-- Actions Left -->
|
||||
<a href="#" class="btn pull-left toggle-summary" aria-label="Toggle summary"><i class="fa fa-align-justify"></i></a>
|
||||
|
||||
@ -46,7 +46,7 @@
|
||||
|
||||
|
||||
|
||||
<div class="book" data-level="2.1" data-basepath=".." data-revision="1402402017737">
|
||||
<div class="book" data-level="2.1" data-basepath=".." data-revision="1402440614492">
|
||||
<div class="book-header">
|
||||
<!-- Actions Left -->
|
||||
<a href="#" class="btn pull-left toggle-summary" aria-label="Toggle summary"><i class="fa fa-align-justify"></i></a>
|
||||
|
||||
@ -46,7 +46,7 @@
|
||||
|
||||
|
||||
|
||||
<div class="book" data-level="2.2" data-basepath=".." data-revision="1402402017737">
|
||||
<div class="book" data-level="2.2" data-basepath=".." data-revision="1402440614492">
|
||||
<div class="book-header">
|
||||
<!-- Actions Left -->
|
||||
<a href="#" class="btn pull-left toggle-summary" aria-label="Toggle summary"><i class="fa fa-align-justify"></i></a>
|
||||
|
||||
@ -46,7 +46,7 @@
|
||||
|
||||
|
||||
|
||||
<div class="book" data-level="2.3" data-basepath=".." data-revision="1402402017737">
|
||||
<div class="book" data-level="2.3" data-basepath=".." data-revision="1402440614492">
|
||||
<div class="book-header">
|
||||
<!-- Actions Left -->
|
||||
<a href="#" class="btn pull-left toggle-summary" aria-label="Toggle summary"><i class="fa fa-align-justify"></i></a>
|
||||
|
||||
@ -46,7 +46,7 @@
|
||||
|
||||
|
||||
|
||||
<div class="book" data-level="2.4" data-basepath=".." data-revision="1402402017737">
|
||||
<div class="book" data-level="2.4" data-basepath=".." data-revision="1402440614492">
|
||||
<div class="book-header">
|
||||
<!-- Actions Left -->
|
||||
<a href="#" class="btn pull-left toggle-summary" aria-label="Toggle summary"><i class="fa fa-align-justify"></i></a>
|
||||
@ -781,7 +781,7 @@ airports["APL"] = nil
|
||||
// Airport code: TYO
|
||||
// Airport code: LHR
|
||||
|
||||
for airportName in airports。values {
|
||||
for airportName in airports.values {
|
||||
prINTln("Airport name: \(airportName)")
|
||||
}
|
||||
// Airport name: Tokyo
|
||||
|
||||
@ -46,7 +46,7 @@
|
||||
|
||||
|
||||
|
||||
<div class="book" data-level="2.5" data-basepath=".." data-revision="1402402017737">
|
||||
<div class="book" data-level="2.5" data-basepath=".." data-revision="1402440614492">
|
||||
<div class="book-header">
|
||||
<!-- Actions Left -->
|
||||
<a href="#" class="btn pull-left toggle-summary" aria-label="Toggle summary"><i class="fa fa-align-justify"></i></a>
|
||||
@ -627,7 +627,7 @@ for _ in 1...power {
|
||||
}
|
||||
println("\(base) to the power of \(power) is \(answer)")
|
||||
// prints "3 to the power of 10 is 59049
|
||||
</code></pre><p>这个例子计算 base 这个数的 power 次幂(本例中,是 3 的 10 次幂),从 1 开始做 3 的乘法(3 的 0 次幂), 进行 10 次,使用 0 到 9 的半闭区间循环。这个计算并不需要知道每一次循环中计数器具体的值,只需要执行了正确的循环次数即可。下划线符号 _ (替代循环中的变量)能够忽略具体的值,并且不提供循环遍历时对值的访问。</p>
|
||||
</code></pre><p>这个例子计算 base 这个数的 power 次幂(本例中,是 3 的 10 次幂),从 1 (3 的 0 次幂)开始做 3 的乘法, 进行 10 次,使用 0 到 9 的半闭区间循环。这个计算并不需要知道每一次循环中计数器具体的值,只需要执行了正确的循环次数即可。下划线符号 _ (替代循环中的变量)能够忽略具体的值,并且不提供循环遍历时对值的访问。</p>
|
||||
<p>使用 <code>for-in</code> 遍历一个数组所有元素:</p>
|
||||
<pre><code>let names = ["Anna", "Alex", "Brian", "Jack"]
|
||||
for name in names {
|
||||
@ -637,7 +637,7 @@ for name in names {
|
||||
// Hello, Alex!
|
||||
// Hello, Brian!
|
||||
// Hello, Jack!
|
||||
</code></pre><p>你也可以通过遍历一个字典来访问它的键值对(key-value pairs)。遍历字典时,字典的每项元素会以 (key, value)元组的形式返回,你可以在 <code>for-in</code> 循环中使用显式的常量名称来解读 (key, value)元组。下面的例子中,字典的键(key)解读为 <code>animalName</code> 常量,字典的值会被解读为 <code>legCount</code> 常量:</p>
|
||||
</code></pre><p>你也可以通过遍历一个字典来访问它的键值对(key-value pairs)。遍历字典时,字典的每项元素会以 (key, value)元组的形式返回,你可以在 <code>for-in</code> 循环中使用显式的常量名称来解读 (key, value)元组。下面的例子中,字典的键(key)解读为常量 <code>animalName</code> ,字典的值会被解读为常量 <code>legCount</code> :</p>
|
||||
<pre><code>let numberOfLegs = ["spider": 8, "ant": 6, "cat": 4]
|
||||
for (animalName, legCount) in numberOfLegs {
|
||||
println("\(animalName)s have \(legCount) legs")
|
||||
|
||||
@ -46,7 +46,7 @@
|
||||
|
||||
|
||||
|
||||
<div class="book" data-level="2.6" data-basepath=".." data-revision="1402402017737">
|
||||
<div class="book" data-level="2.6" data-basepath=".." data-revision="1402440614492">
|
||||
<div class="book-header">
|
||||
<!-- Actions Left -->
|
||||
<a href="#" class="btn pull-left toggle-summary" aria-label="Toggle summary"><i class="fa fa-align-justify"></i></a>
|
||||
|
||||
@ -46,7 +46,7 @@
|
||||
|
||||
|
||||
|
||||
<div class="book" data-level="2.7" data-basepath=".." data-revision="1402402017737">
|
||||
<div class="book" data-level="2.7" data-basepath=".." data-revision="1402440614492">
|
||||
<div class="book-header">
|
||||
<!-- Actions Left -->
|
||||
<a href="#" class="btn pull-left toggle-summary" aria-label="Toggle summary"><i class="fa fa-align-justify"></i></a>
|
||||
|
||||
@ -46,7 +46,7 @@
|
||||
|
||||
|
||||
|
||||
<div class="book" data-level="2.8" data-basepath=".." data-revision="1402402017737">
|
||||
<div class="book" data-level="2.8" data-basepath=".." data-revision="1402440614492">
|
||||
<div class="book-header">
|
||||
<!-- Actions Left -->
|
||||
<a href="#" class="btn pull-left toggle-summary" aria-label="Toggle summary"><i class="fa fa-align-justify"></i></a>
|
||||
@ -589,20 +589,21 @@
|
||||
|
||||
<section class="normal" id="section-gitbook_37">
|
||||
|
||||
<h1 id="-">枚举</h1>
|
||||
<h1 id="-enumerations-">枚举(Enumerations)</h1>
|
||||
<hr>
|
||||
<p>本页内容包含:</p>
|
||||
<ul>
|
||||
<li>枚举语法</li>
|
||||
<li>匹配枚举值与<code>Swith</code>语句</li>
|
||||
<li>关联值(associated values)</li>
|
||||
<li>原始值(raw values)</li>
|
||||
<li><a href="#enumeration_syntax">枚举语法(Enumeration Syntax)</a></li>
|
||||
<li><a href="#matching_enumeration_values_with_a_switch_statement">匹配枚举值与<code>Switch</code>语句(Matching Enumeration Values with a Switch Statement)</a></li>
|
||||
<li><a href="#associated_values">关联值(Associated values)</a></li>
|
||||
<li><a href="#raw_values">原始值(Raw values)</a></li>
|
||||
</ul>
|
||||
<p>枚举(enumeration)定义了一个通用类型的一组相关的值,使你可以在你的代码中以一个安全的方式来使用这些值。</p>
|
||||
<p>如果你熟悉C语言,你就会知道,在C语言中枚举指定相关名称为一组整型值。Swift中的枚举更加灵活,不必给每一个枚举成员(enumeration member)提供一个值。如果一个值(被认为是“原始”值)被提供给每个枚举成员,则该值可以是一个字符串,一个字符,或是一个整型值或浮点值。</p>
|
||||
<p><strong>枚举</strong>定义了一个通用类型的一组相关的值,使你可以在你的代码中以一个安全的方式来使用这些值。</p>
|
||||
<p>如果你熟悉 C 语言,你就会知道,在 C 语言中枚举指定相关名称为一组整型值。Swift 中的枚举更加灵活,不必给每一个枚举成员(enumeration member)提供一个值。如果一个值(被认为是“原始”值)被提供给每个枚举成员,则该值可以是一个字符串,一个字符,或是一个整型值或浮点值。</p>
|
||||
<p>此外,枚举成员可以指定任何类型的关联值存储到枚举成员值中,就像其他语言中的联合体(unions)和变体(variants)。你可以定义一组通用的相关成员作为枚举的一部分,每一组都有不同的一组与它相关的适当类型的数值。</p>
|
||||
<p>在Swift中,枚举类型是一等(first-class)类型。它们采用了很多传统上只被类(class)所支持的特征,例如计算型属性(computed properties),用于提供关于枚举当前值的附加信息,实例方法(instance methods),用于提供和枚举所代表的值相关联的功能。枚举也可以定义构造函数(initializers)来提供一个初始成员值;可以在原始的实现基础上扩展它们的功能;可以遵守协议(protocols)来提供标准的功能。</p>
|
||||
<p>欲了解更多相关功能,请参见属性(Properties),方法(Methods),构造过程(Initialization),扩展(Extensions),和协议(Protocols)。</p>
|
||||
<p>在 Swift 中,枚举类型是一等(first-class)类型。它们采用了很多传统上只被类所支持的特征,例如计算型属性(computed properties),用于提供关于枚举当前值的附加信息,实例方法(instance methods),用于提供和枚举所代表的值相关联的功能。枚举也可以定义构造器(initializers)来提供一个初始成员值;可以在原始的实现基础上扩展它们的功能;可以遵守协议(protocols)来提供标准的功能。</p>
|
||||
<p>欲了解更多相关功能,请参考<a href="../chapter2/10_Properties.html">属性</a>,<a href="../chapter2/11_Methodes.html">方法</a>,<a href="../chapter2/14_Initialization.html">构造过程</a>,<a href="../chapter2/20_Extensions.html">扩展</a>,和<a href="../chapter2/21_Protocols.html">协议</a>。</p>
|
||||
<p><a name="enumeration_syntax"></a></p>
|
||||
<h2 id="-">枚举语法</h2>
|
||||
<p>使用<code>enum</code>关键词并且把它们的整个定义放在一对大括号内:</p>
|
||||
<pre><code>enum SomeEumeration {
|
||||
@ -618,17 +619,18 @@
|
||||
</code></pre><p>一个枚举中被定义的值(例如 <code>North</code>,<code>South</code>,<code>East</code>和<code>West</code>)是枚举的<strong><em>成员值</em></strong>(或者<strong><em>成员</em></strong>)。<code>case</code>关键词表明新的一行成员值将被定义。</p>
|
||||
<blockquote>
|
||||
<p>注意:
|
||||
不像C和Objective-C一样,Swift的枚举成员在被创建时不会被赋予一个默认的整数值。在上面的<code>CompassPoints</code>例子中,<code>North</code>,<code>South</code>,<code>East</code>和<code>West</code>不是隐式得等于<code>0</code>,<code>1</code>,<code>2</code>和<code>3</code>。相反的,这些不同的枚举成员在<code>CompassPoint</code>的一种显示定义中拥有各自不同的值。</p>
|
||||
不像 C 和 Objective-C 一样,Swift 的枚举成员在被创建时不会被赋予一个默认的整数值。在上面的<code>CompassPoints</code>例子中,<code>North</code>,<code>South</code>,<code>East</code>和<code>West</code>不是隐式得等于<code>0</code>,<code>1</code>,<code>2</code>和<code>3</code>。相反的,这些不同的枚举成员在<code>CompassPoint</code>的一种显示定义中拥有各自不同的值。</p>
|
||||
</blockquote>
|
||||
<p>多个成员值可以出现在同一行上,用逗号隔开:</p>
|
||||
<pre><code>enum Planet {
|
||||
case Mercury, Venus, Earth, Mars, Jupiter, Saturn, Uranus, Nepturn
|
||||
}
|
||||
</code></pre><p>每个枚举定义了一个全新的类型。像Swift中其他类型一样,它们的名字(例如<code>CompassPoint</code>和<code>Planet</code>)必须以一个大写字母开头。给枚举类型起一个单数名字而不是复数名字,以便于读起来更加容易理解:</p>
|
||||
</code></pre><p>每个枚举定义了一个全新的类型。像 Swift 中其他类型一样,它们的名字(例如<code>CompassPoint</code>和<code>Planet</code>)必须以一个大写字母开头。给枚举类型起一个单数名字而不是复数名字,以便于读起来更加容易理解:</p>
|
||||
<pre><code>var directionToHead = CompassPoint.West
|
||||
</code></pre><p><code>directionToHead</code>的类型被推断当它被<code>CompassPoint</code>的一个可能值初始化。一旦<code>directionToHead</code>被声明为一个<code>CompassPoint</code>,你可以使用更短的点(.)语法将其设置为另一个<code>CompassPoint</code>的值:</p>
|
||||
<pre><code>directionToHead = .East
|
||||
</code></pre><p><code>directionToHead</code>的类型已知时,当设定它的值时,你可以不再写类型名。使用显示类型的枚举值可以让代码具有更好的可读性。</p>
|
||||
<p><a name="matching_enumeration_values_with_a_switch_statement"></a></p>
|
||||
<h2 id="-switch-">匹配枚举值和<code>Switch</code>语句</h2>
|
||||
<p>你可以匹配单个枚举值和<code>switch</code>语句:</p>
|
||||
<pre><code>directionToHead = .South
|
||||
@ -646,7 +648,7 @@ case .West:
|
||||
</code></pre><p>你可以如此理解这段代码:</p>
|
||||
<p>“考虑<code>directionToHead</code>的值。当它等于<code>.North</code>,打印<code>“Lots of planets have a north”</code>。当它等于<code>.South</code>,打印<code>“Watch out for penguins”</code>。”</p>
|
||||
<p>等等依次类推。</p>
|
||||
<p>正如在控制流(Control Flow)中介绍,当考虑一个枚举的成员们时,一个<code>switch</code>语句必须全面。如果忽略了<code>.West</code>这种情况,上面那段代码将无法通过编译,因为它没有考虑到<code>CompassPoint</code>的全部成员。全面性的要求确保了枚举成员不会被意外遗漏。</p>
|
||||
<p>正如在<a href="../chapter2/05_Control_Flow.html">控制流</a>中介绍,当考虑一个枚举的成员们时,一个<code>switch</code>语句必须全面。如果忽略了<code>.West</code>这种情况,上面那段代码将无法通过编译,因为它没有考虑到<code>CompassPoint</code>的全部成员。全面性的要求确保了枚举成员不会被意外遗漏。</p>
|
||||
<p>当不需要匹配每个枚举成员的时候,你可以提供一个默认<code>default</code>分支来涵盖所有未明确被提出的任何成员:</p>
|
||||
<pre><code>let somePlanet = Planet.Earth
|
||||
switch somePlanet {
|
||||
@ -656,15 +658,16 @@ default:
|
||||
println("Not a safe place for humans")
|
||||
}
|
||||
// prints "Mostly harmless”
|
||||
</code></pre><h2 id="-associated-values-">关联值(Associated Values)</h2>
|
||||
</code></pre><p><a name="associated_values"></a></p>
|
||||
<h2 id="-associated-values-">关联值(Associated Values)</h2>
|
||||
<p>上一小节的例子演示了一个枚举的成员是如何被定义(分类)的。你可以为<code>Planet.Earth</code>设置一个常量或则变量,并且在之后查看这个值。然而,有时候会很有用如果能够把其他类型的关联值和成员值一起存储起来。这能让你随着成员值存储额外的自定义信息,并且当每次你在代码中利用该成员时允许这个信息产生变化。</p>
|
||||
<p>你可以定义Swift的枚举存储任何类型的关联值,如果需要的话,每个成员的数据类型可以是各不相同的。枚举的这种特性跟其他语言中的可辨识联合(discriminated unions),标签联合(tagged unions),或者变体(variants)相似。</p>
|
||||
<p>例如,假设一个库存跟踪系统需要利用两种不同类型的条形码来跟踪商品。有些商品上标有UPC-A格式的一维码,它使用数字0到9.每一个条形码都有一个代表“数字系统”的数字,该数字后接10个代表“标识符”的数字。最后一个数字是“检查”位,用来验证代码是否被正确扫描:</p>
|
||||
<p>你可以定义 Swift 的枚举存储任何类型的关联值,如果需要的话,每个成员的数据类型可以是各不相同的。枚举的这种特性跟其他语言中的可辨识联合(discriminated unions),标签联合(tagged unions),或者变体(variants)相似。</p>
|
||||
<p>例如,假设一个库存跟踪系统需要利用两种不同类型的条形码来跟踪商品。有些商品上标有 UPC-A 格式的一维码,它使用数字0到9.每一个条形码都有一个代表“数字系统”的数字,该数字后接10个代表“标识符”的数字。最后一个数字是“检查”位,用来验证代码是否被正确扫描:</p>
|
||||
<p><img width="252" height="120" a"" src="https://developer.apple.com/library/prerelease/ios/documentation/Swift/Conceptual/Swift_Programming_Language/Art/barcode_UPC_2x.png"></p>
|
||||
<p>其他商品上标有QR码格式的二维码,它可以使用任何ISO8859-1字符,并且可以编码一个最多拥有2,953字符的字符串:</p>
|
||||
<p>其他商品上标有 QR 码格式的二维码,它可以使用任何 ISO8859-1 字符,并且可以编码一个最多拥有2,953字符的字符串:</p>
|
||||
<p><img width="169" height="169" alt="" src="https://developer.apple.com/library/prerelease/ios/documentation/Swift/Conceptual/Swift_Programming_Language/Art/barcode_QR_2x.png"></p>
|
||||
<p>对于库存跟踪系统来说,能够把UPC-A码作为三个整型值的元组,和把QR码作为一个任何长度的字符串存储起来是方便的。</p>
|
||||
<p>在Swift中,用来定义两种商品条码的枚举是这样子的:</p>
|
||||
<p>对于库存跟踪系统来说,能够把 UPC-A 码作为三个整型值的元组,和把 QR 码作为一个任何长度的字符串存储起来是方便的。</p>
|
||||
<p>在 Swift 中,用来定义两种商品条码的枚举是这样子的:</p>
|
||||
<pre><code>enum Barcode {
|
||||
case UPCA(Int, Int, Int)
|
||||
case QRCode(String)
|
||||
@ -678,7 +681,7 @@ default:
|
||||
<p>同一个商品可以被分配给一个不同类型的条形码,如:</p>
|
||||
<pre><code>productBarcode = .QRCode("ABCDEFGHIJKLMNOP")
|
||||
</code></pre><p>这时,原始的<code>Barcode.UPCA</code>和其整数值被新的<code>Barcode.QRCode</code>和其字符串值所替代。条形码的常量和变量可以存储一个<code>.UPCA</code>或者一个<code>.QRCode</code>(连同它的关联值),但是在任何指定时间只能存储其中之一。</p>
|
||||
<p>像以前那样,不同的条形码类型可以使用一个switch语句来检查,然而这次关联值可以被提取作为switch语句的一部分。你可以在<code>switch</code>的case分支代码中提取每个关联值作为一个常量(用<code>let</code>前缀)或者作为一个变量(用<code>var</code>前缀)来使用:</p>
|
||||
<p>像以前那样,不同的条形码类型可以使用一个<code>switch</code>语句来检查,然而这次关联值可以被提取作为<code>switch</code>语句的一部分。你可以在<code>switch</code>的case分支代码中提取每个关联值作为一个常量(用<code>let</code>前缀)或者作为一个变量(用<code>var</code>前缀)来使用:</p>
|
||||
<pre><code>switch productBarcode {
|
||||
case .UPCA(let numberSystem, let identifier, let check):
|
||||
println("UPC-A with value of \(numberSystem), \(identifier), \(check).")
|
||||
@ -694,18 +697,19 @@ case let .QRCode(productCode):
|
||||
println("QR code with value of \(productCode).")
|
||||
}
|
||||
// prints "QR code with value of ABCDEFGHIJKLMNOP."
|
||||
</code></pre><h2 id="-raw-values-">原始值(Raw Values)</h2>
|
||||
</code></pre><p><a name="raw_values"></a></p>
|
||||
<h2 id="-raw-values-">原始值(Raw Values)</h2>
|
||||
<p>在关联值小节的条形码例子中演示了一个枚举的成员如何声明它们存储不同类型的关联值。作为关联值的替代,枚举成员可以被默认值(称为原始值)预先填充,其中这些原始值具有相同的类型。</p>
|
||||
<p>这里是一个枚举成员存储原始ASCII值的例子:</p>
|
||||
<p>这里是一个枚举成员存储原始 ASCII 值的例子:</p>
|
||||
<pre><code>enum ASCIIControlCharacter: Character {
|
||||
case Tab = "\t"
|
||||
case LineFeed = "\n"
|
||||
case CarriageReturn = "\r"
|
||||
}
|
||||
</code></pre><p>在这里,称为<code>ASCIIControlCharacter</code>的枚举的原始值类型被定义为字符型<code>Character</code>,并被设置了一些比较常见的ASCII控制字符。字符值的描述请详见字符串和字符<code>Strings and Characters</code>部分。</p>
|
||||
<p>注意,原始值和关联值是不相同的。当你开始在你的代码中定义枚举的时候原始值是被预先填充的值,像上述三个ASCII码。对于一个特定的枚举成员,它的原始值始终是相同的。关联值是当你在创建一个基于枚举成员的新常量或变量时才会被设置,并且每次当你这么做得时候,它的值可以是不同的。</p>
|
||||
</code></pre><p>在这里,称为<code>ASCIIControlCharacter</code>的枚举的原始值类型被定义为字符型<code>Character</code>,并被设置了一些比较常见的 ASCII 控制字符。字符值的描述请详见<a href="../chapter2/03_Strings_and_Characters.html">字符串和字符</a>章节。</p>
|
||||
<p>注意,原始值和关联值是不相同的。当你开始在你的代码中定义枚举的时候原始值是被预先填充的值,像上述三个 ASCII 码。对于一个特定的枚举成员,它的原始值始终是相同的。关联值是当你在创建一个基于枚举成员的新常量或变量时才会被设置,并且每次当你这么做得时候,它的值可以是不同的。</p>
|
||||
<p>原始值可以是字符串,字符,或者任何整型值或浮点型值。每个原始值在它的枚举声明中必须是唯一的。当整型值被用于原始值,如果其他枚举成员没有值时,它们会自动递增。</p>
|
||||
<p>下面的枚举是对之前<code>Planet</code>这个枚举的一个细化,利用原始整型值来表示每个planet在太阳系中的顺序:</p>
|
||||
<p>下面的枚举是对之前<code>Planet</code>这个枚举的一个细化,利用原始整型值来表示每个 planet 在太阳系中的顺序:</p>
|
||||
<pre><code>enum Planet: Int {
|
||||
case Mercury = 1, Venus, Earth, Mars, Jupiter, Saturn, Uranus, Neptune
|
||||
}
|
||||
|
||||
@ -46,7 +46,7 @@
|
||||
|
||||
|
||||
|
||||
<div class="book" data-level="2.9" data-basepath=".." data-revision="1402402017737">
|
||||
<div class="book" data-level="2.9" data-basepath=".." data-revision="1402440614492">
|
||||
<div class="book-header">
|
||||
<!-- Actions Left -->
|
||||
<a href="#" class="btn pull-left toggle-summary" aria-label="Toggle summary"><i class="fa fa-align-justify"></i></a>
|
||||
|
||||
@ -46,7 +46,7 @@
|
||||
|
||||
|
||||
|
||||
<div class="book" data-level="2.10" data-basepath=".." data-revision="1402402017737">
|
||||
<div class="book" data-level="2.10" data-basepath=".." data-revision="1402440614492">
|
||||
<div class="book-header">
|
||||
<!-- Actions Left -->
|
||||
<a href="#" class="btn pull-left toggle-summary" aria-label="Toggle summary"><i class="fa fa-align-justify"></i></a>
|
||||
|
||||
@ -46,7 +46,7 @@
|
||||
|
||||
|
||||
|
||||
<div class="book" data-level="2.11" data-basepath=".." data-revision="1402402017737">
|
||||
<div class="book" data-level="2.11" data-basepath=".." data-revision="1402440614492">
|
||||
<div class="book-header">
|
||||
<!-- Actions Left -->
|
||||
<a href="#" class="btn pull-left toggle-summary" aria-label="Toggle summary"><i class="fa fa-align-justify"></i></a>
|
||||
|
||||
@ -46,7 +46,7 @@
|
||||
|
||||
|
||||
|
||||
<div class="book" data-level="2.12" data-basepath=".." data-revision="1402402017737">
|
||||
<div class="book" data-level="2.12" data-basepath=".." data-revision="1402440614492">
|
||||
<div class="book-header">
|
||||
<!-- Actions Left -->
|
||||
<a href="#" class="btn pull-left toggle-summary" aria-label="Toggle summary"><i class="fa fa-align-justify"></i></a>
|
||||
|
||||
@ -46,7 +46,7 @@
|
||||
|
||||
|
||||
|
||||
<div class="book" data-level="2.13" data-basepath=".." data-revision="1402402017737">
|
||||
<div class="book" data-level="2.13" data-basepath=".." data-revision="1402440614492">
|
||||
<div class="book-header">
|
||||
<!-- Actions Left -->
|
||||
<a href="#" class="btn pull-left toggle-summary" aria-label="Toggle summary"><i class="fa fa-align-justify"></i></a>
|
||||
|
||||
@ -46,7 +46,7 @@
|
||||
|
||||
|
||||
|
||||
<div class="book" data-level="2.14" data-basepath=".." data-revision="1402402017737">
|
||||
<div class="book" data-level="2.14" data-basepath=".." data-revision="1402440614492">
|
||||
<div class="book-header">
|
||||
<!-- Actions Left -->
|
||||
<a href="#" class="btn pull-left toggle-summary" aria-label="Toggle summary"><i class="fa fa-align-justify"></i></a>
|
||||
|
||||
@ -46,7 +46,7 @@
|
||||
|
||||
|
||||
|
||||
<div class="book" data-level="2.15" data-basepath=".." data-revision="1402402017737">
|
||||
<div class="book" data-level="2.15" data-basepath=".." data-revision="1402440614492">
|
||||
<div class="book-header">
|
||||
<!-- Actions Left -->
|
||||
<a href="#" class="btn pull-left toggle-summary" aria-label="Toggle summary"><i class="fa fa-align-justify"></i></a>
|
||||
|
||||
@ -46,7 +46,7 @@
|
||||
|
||||
|
||||
|
||||
<div class="book" data-level="2.16" data-basepath=".." data-revision="1402402017737">
|
||||
<div class="book" data-level="2.16" data-basepath=".." data-revision="1402440614492">
|
||||
<div class="book-header">
|
||||
<!-- Actions Left -->
|
||||
<a href="#" class="btn pull-left toggle-summary" aria-label="Toggle summary"><i class="fa fa-align-justify"></i></a>
|
||||
|
||||
@ -46,7 +46,7 @@
|
||||
|
||||
|
||||
|
||||
<div class="book" data-level="2.17" data-basepath=".." data-revision="1402402017737">
|
||||
<div class="book" data-level="2.17" data-basepath=".." data-revision="1402440614492">
|
||||
<div class="book-header">
|
||||
<!-- Actions Left -->
|
||||
<a href="#" class="btn pull-left toggle-summary" aria-label="Toggle summary"><i class="fa fa-align-justify"></i></a>
|
||||
|
||||
@ -46,7 +46,7 @@
|
||||
|
||||
|
||||
|
||||
<div class="book" data-level="2.18" data-basepath=".." data-revision="1402402017737">
|
||||
<div class="book" data-level="2.18" data-basepath=".." data-revision="1402440614492">
|
||||
<div class="book-header">
|
||||
<!-- Actions Left -->
|
||||
<a href="#" class="btn pull-left toggle-summary" aria-label="Toggle summary"><i class="fa fa-align-justify"></i></a>
|
||||
|
||||
@ -46,7 +46,7 @@
|
||||
|
||||
|
||||
|
||||
<div class="book" data-level="2.19" data-basepath=".." data-revision="1402402017737">
|
||||
<div class="book" data-level="2.19" data-basepath=".." data-revision="1402440614492">
|
||||
<div class="book-header">
|
||||
<!-- Actions Left -->
|
||||
<a href="#" class="btn pull-left toggle-summary" aria-label="Toggle summary"><i class="fa fa-align-justify"></i></a>
|
||||
|
||||
@ -46,7 +46,7 @@
|
||||
|
||||
|
||||
|
||||
<div class="book" data-level="2.20" data-basepath=".." data-revision="1402402017737">
|
||||
<div class="book" data-level="2.20" data-basepath=".." data-revision="1402440614492">
|
||||
<div class="book-header">
|
||||
<!-- Actions Left -->
|
||||
<a href="#" class="btn pull-left toggle-summary" aria-label="Toggle summary"><i class="fa fa-align-justify"></i></a>
|
||||
|
||||
@ -46,7 +46,7 @@
|
||||
|
||||
|
||||
|
||||
<div class="book" data-level="2.21" data-basepath=".." data-revision="1402402017737">
|
||||
<div class="book" data-level="2.21" data-basepath=".." data-revision="1402440614492">
|
||||
<div class="book-header">
|
||||
<!-- Actions Left -->
|
||||
<a href="#" class="btn pull-left toggle-summary" aria-label="Toggle summary"><i class="fa fa-align-justify"></i></a>
|
||||
@ -587,7 +587,7 @@
|
||||
|
||||
<div class="page-inner">
|
||||
|
||||
<section class="normal" id="section-gitbook_64">
|
||||
<section class="normal" id="section-gitbook_61">
|
||||
|
||||
<h1 id="-">协议</h1>
|
||||
<hr>
|
||||
|
||||
@ -46,7 +46,7 @@
|
||||
|
||||
|
||||
|
||||
<div class="book" data-level="2.22" data-basepath=".." data-revision="1402402017737">
|
||||
<div class="book" data-level="2.22" data-basepath=".." data-revision="1402440614492">
|
||||
<div class="book-header">
|
||||
<!-- Actions Left -->
|
||||
<a href="#" class="btn pull-left toggle-summary" aria-label="Toggle summary"><i class="fa fa-align-justify"></i></a>
|
||||
@ -587,7 +587,7 @@
|
||||
|
||||
<div class="page-inner">
|
||||
|
||||
<section class="normal" id="section-gitbook_61">
|
||||
<section class="normal" id="section-gitbook_63">
|
||||
|
||||
<h1 id="-">泛型</h1>
|
||||
<hr>
|
||||
|
||||
@ -46,7 +46,7 @@
|
||||
|
||||
|
||||
|
||||
<div class="book" data-level="2.23" data-basepath=".." data-revision="1402402017737">
|
||||
<div class="book" data-level="2.23" data-basepath=".." data-revision="1402440614492">
|
||||
<div class="book-header">
|
||||
<!-- Actions Left -->
|
||||
<a href="#" class="btn pull-left toggle-summary" aria-label="Toggle summary"><i class="fa fa-align-justify"></i></a>
|
||||
@ -587,7 +587,7 @@
|
||||
|
||||
<div class="page-inner">
|
||||
|
||||
<section class="normal" id="section-gitbook_66">
|
||||
<section class="normal" id="section-gitbook_67">
|
||||
|
||||
<p>In addition to the operators described in <a href="Basic Operators">Basic Operators</a>, Swift provides several advanced operators that perform more complex value manipulation. These include all of the bitwise and bit shifting operators you will be familiar with from C and Objective-C.</p>
|
||||
<p>除于<a href="Basic Operators">基本操作符</a>中所讲的运算符, Swift还有许多复杂的高级运算符, 包括了C语和Objective-C中的位运算符和位移运算.</p>
|
||||
|
||||
@ -46,7 +46,7 @@
|
||||
|
||||
|
||||
|
||||
<div class="book" data-level="2" data-basepath=".." data-revision="1402402017737">
|
||||
<div class="book" data-level="2" data-basepath=".." data-revision="1402440614492">
|
||||
<div class="book-header">
|
||||
<!-- Actions Left -->
|
||||
<a href="#" class="btn pull-left toggle-summary" aria-label="Toggle summary"><i class="fa fa-align-justify"></i></a>
|
||||
@ -587,7 +587,7 @@
|
||||
|
||||
<div class="page-inner">
|
||||
|
||||
<section class="normal" id="section-gitbook_67">
|
||||
<section class="normal" id="section-gitbook_66">
|
||||
|
||||
<h1 id="swift-">Swift 教程</h1>
|
||||
<p>本章介绍了 Swift 的各种特性及其使用方法,是全书的核心部分。</p>
|
||||
|
||||
@ -46,7 +46,7 @@
|
||||
|
||||
|
||||
|
||||
<div class="book" data-level="3.1" data-basepath=".." data-revision="1402402017737">
|
||||
<div class="book" data-level="3.1" data-basepath=".." data-revision="1402440614492">
|
||||
<div class="book-header">
|
||||
<!-- Actions Left -->
|
||||
<a href="#" class="btn pull-left toggle-summary" aria-label="Toggle summary"><i class="fa fa-align-justify"></i></a>
|
||||
|
||||
@ -46,7 +46,7 @@
|
||||
|
||||
|
||||
|
||||
<div class="book" data-level="3.2" data-basepath=".." data-revision="1402402017737">
|
||||
<div class="book" data-level="3.2" data-basepath=".." data-revision="1402440614492">
|
||||
<div class="book-header">
|
||||
<!-- Actions Left -->
|
||||
<a href="#" class="btn pull-left toggle-summary" aria-label="Toggle summary"><i class="fa fa-align-justify"></i></a>
|
||||
|
||||
@ -46,7 +46,7 @@
|
||||
|
||||
|
||||
|
||||
<div class="book" data-level="3.3" data-basepath=".." data-revision="1402402017737">
|
||||
<div class="book" data-level="3.3" data-basepath=".." data-revision="1402440614492">
|
||||
<div class="book-header">
|
||||
<!-- Actions Left -->
|
||||
<a href="#" class="btn pull-left toggle-summary" aria-label="Toggle summary"><i class="fa fa-align-justify"></i></a>
|
||||
|
||||
@ -46,7 +46,7 @@
|
||||
|
||||
|
||||
|
||||
<div class="book" data-level="3.4" data-basepath=".." data-revision="1402402017737">
|
||||
<div class="book" data-level="3.4" data-basepath=".." data-revision="1402440614492">
|
||||
<div class="book-header">
|
||||
<!-- Actions Left -->
|
||||
<a href="#" class="btn pull-left toggle-summary" aria-label="Toggle summary"><i class="fa fa-align-justify"></i></a>
|
||||
|
||||
@ -46,7 +46,7 @@
|
||||
|
||||
|
||||
|
||||
<div class="book" data-level="3.6" data-basepath=".." data-revision="1402402017737">
|
||||
<div class="book" data-level="3.6" data-basepath=".." data-revision="1402440614492">
|
||||
<div class="book-header">
|
||||
<!-- Actions Left -->
|
||||
<a href="#" class="btn pull-left toggle-summary" aria-label="Toggle summary"><i class="fa fa-align-justify"></i></a>
|
||||
|
||||
@ -46,7 +46,7 @@
|
||||
|
||||
|
||||
|
||||
<div class="book" data-level="3.7" data-basepath=".." data-revision="1402402017737">
|
||||
<div class="book" data-level="3.7" data-basepath=".." data-revision="1402440614492">
|
||||
<div class="book-header">
|
||||
<!-- Actions Left -->
|
||||
<a href="#" class="btn pull-left toggle-summary" aria-label="Toggle summary"><i class="fa fa-align-justify"></i></a>
|
||||
|
||||
@ -46,7 +46,7 @@
|
||||
|
||||
|
||||
|
||||
<div class="book" data-level="3.8" data-basepath=".." data-revision="1402402017737">
|
||||
<div class="book" data-level="3.8" data-basepath=".." data-revision="1402440614492">
|
||||
<div class="book-header">
|
||||
<!-- Actions Left -->
|
||||
<a href="#" class="btn pull-left toggle-summary" aria-label="Toggle summary"><i class="fa fa-align-justify"></i></a>
|
||||
|
||||
@ -46,7 +46,7 @@
|
||||
|
||||
|
||||
|
||||
<div class="book" data-level="3.9" data-basepath=".." data-revision="1402402017737">
|
||||
<div class="book" data-level="3.9" data-basepath=".." data-revision="1402440614492">
|
||||
<div class="book-header">
|
||||
<!-- Actions Left -->
|
||||
<a href="#" class="btn pull-left toggle-summary" aria-label="Toggle summary"><i class="fa fa-align-justify"></i></a>
|
||||
|
||||
@ -44,7 +44,7 @@
|
||||
|
||||
|
||||
|
||||
<div class="book" data-level="3.10" data-basepath=".." data-revision="1402402017737">
|
||||
<div class="book" data-level="3.10" data-basepath=".." data-revision="1402440614492">
|
||||
<div class="book-header">
|
||||
<!-- Actions Left -->
|
||||
<a href="#" class="btn pull-left toggle-summary" aria-label="Toggle summary"><i class="fa fa-align-justify"></i></a>
|
||||
@ -585,7 +585,7 @@
|
||||
|
||||
<div class="page-inner">
|
||||
|
||||
<section class="normal" id="section-gitbook_86">
|
||||
<section class="normal" id="section-gitbook_83">
|
||||
|
||||
<h1 id="-">语法总结</h1>
|
||||
<hr>
|
||||
|
||||
@ -46,7 +46,7 @@
|
||||
|
||||
|
||||
|
||||
<div class="book" data-level="3.5" data-basepath=".." data-revision="1402402017737">
|
||||
<div class="book" data-level="3.5" data-basepath=".." data-revision="1402440614492">
|
||||
<div class="book-header">
|
||||
<!-- Actions Left -->
|
||||
<a href="#" class="btn pull-left toggle-summary" aria-label="Toggle summary"><i class="fa fa-align-justify"></i></a>
|
||||
@ -587,7 +587,7 @@
|
||||
|
||||
<div class="page-inner">
|
||||
|
||||
<section class="normal" id="section-gitbook_83">
|
||||
<section class="normal" id="section-gitbook_85">
|
||||
|
||||
<h1 id="-">语句</h1>
|
||||
<hr>
|
||||
@ -632,7 +632,7 @@
|
||||
<li><p>计算<em>increment</em>表达式,然后转到第2步。</p>
|
||||
</li>
|
||||
</ol>
|
||||
<p>定义在<em>initialzation</em>中的变量仅在<code>for</code>语句的作用域以内有效。<em>condition</em>表达式的值的类型必须符合<code>LogicValue</code>协议。</p>
|
||||
<p>定义在<em>initialzation</em>中的变量仅在<code>for</code>语句的作用域以内有效。<em>condition</em>表达式的值的类型必须遵循<code>LogicValue</code>协议。</p>
|
||||
<blockquote>
|
||||
<p>GRAMMAR OF A FOR STATEMENT</p>
|
||||
<p><em>for-statement</em> → <strong>for</strong> <a href="https://developer.apple.com/library/prerelease/ios/documentation/Swift/Conceptual/Swift_Programming_Language/Statements.html#//apple_ref/swift/grammar/for-init" target="_blank"><em>for-init</em></a> <em>opt</em> <strong>;</strong> <a href="https://developer.apple.com/library/prerelease/ios/documentation/Swift/Conceptual/Swift_Programming_Language/Expressions.html#//apple_ref/swift/grammar/expression" target="_blank"><em>expression</em></a> <em>opt</em> <strong>;</strong> <a href="https://developer.apple.com/library/prerelease/ios/documentation/Swift/Conceptual/Swift_Programming_Language/Expressions.html#//apple_ref/swift/grammar/expression" target="_blank"><em>expression</em></a> <em>opt</em> <a href="https://developer.apple.com/library/prerelease/ios/documentation/Swift/Conceptual/Swift_Programming_Language/Declarations.html#//apple_ref/swift/grammar/code-block" target="_blank"><em>code-block</em></a></p>
|
||||
@ -640,13 +640,13 @@
|
||||
<p><em>for-statement</em> → <a href="https://developer.apple.com/library/prerelease/ios/documentation/Swift/Conceptual/Swift_Programming_Language/Declarations.html#//apple_ref/swift/grammar/variable-declaration" target="_blank"><em>variable-declaration</em></a> | <a href="https://developer.apple.com/library/prerelease/ios/documentation/Swift/Conceptual/Swift_Programming_Language/Expressions.html#//apple_ref/swift/grammar/expression-list" target="_blank"><em>expression-list</em></a></p>
|
||||
</blockquote>
|
||||
<h3 id="for-in-">For-In 语句</h3>
|
||||
<p><code>for-in</code>语句允许在重复执行代码块的同时,迭代集合(或符合<code>Sequence</code>协议的任意类型)中的每一项。</p>
|
||||
<p><code>for-in</code>语句允许在重复执行代码块的同时,迭代集合(或遵循<code>Sequence</code>协议的任意类型)中的每一项。</p>
|
||||
<p><code>for-in</code>语句的形式如下:</p>
|
||||
<pre><code class="lang-swift">for `item` in `collection` {
|
||||
`statements`
|
||||
}
|
||||
</code></pre>
|
||||
<p><code>for-in</code>语句在循环开始前会调用<em>collection</em>表达式的<code>generate</code>方法来获取一个生成器类型(这是一个符合<code>Generator</code>协议的类型)的值。接下来循环开始,调用<em>collection</em>表达式的<code>next</code>方法。如果其返回值不是<code>None</code>,它将会被赋给<em>item</em>,然后执行<em>statements</em>,执行完毕后回到循环开始处;否则,将不会赋值给<em>item</em>也不会执行<em>statements</em>,<code>for-in</code>至此执行完毕。</p>
|
||||
<p><code>for-in</code>语句在循环开始前会调用<em>collection</em>表达式的<code>generate</code>方法来获取一个生成器类型(这是一个遵循<code>Generator</code>协议的类型)的值。接下来循环开始,调用<em>collection</em>表达式的<code>next</code>方法。如果其返回值不是<code>None</code>,它将会被赋给<em>item</em>,然后执行<em>statements</em>,执行完毕后回到循环开始处;否则,将不会赋值给<em>item</em>也不会执行<em>statements</em>,<code>for-in</code>至此执行完毕。</p>
|
||||
<blockquote>
|
||||
<p>GRAMMAR OF A FOR-IN STATEMENT</p>
|
||||
<p><em>for-in-statement</em> → <strong>for</strong> <a href="https://developer.apple.com/library/prerelease/ios/documentation/Swift/Conceptual/Swift_Programming_Language/Patterns.html#//apple_ref/swift/grammar/pattern" target="_blank"><em>pattern</em></a> <strong>in</strong> <a href="https://developer.apple.com/library/prerelease/ios/documentation/Swift/Conceptual/Swift_Programming_Language/Expressions.html#//apple_ref/swift/grammar/expression" target="_blank"><em>expression</em></a> <a href="https://developer.apple.com/library/prerelease/ios/documentation/Swift/Conceptual/Swift_Programming_Language/Declarations.html#//apple_ref/swift/grammar/code-block" target="_blank"><em>code-block</em></a></p>
|
||||
@ -667,7 +667,7 @@
|
||||
</li>
|
||||
</ol>
|
||||
<p>由于<em>condition</em>的值在<em>statements</em>执行前就已计算出,因此<code>while</code>语句中的<em>statements</em>可能会被执行若干次,也可能不会被执行。</p>
|
||||
<p><em>condition</em>表达式的值的类型必须符合<code>LogicValue</code>协议。同时,<em>condition</em>表达式也可以使用可选绑定,请参考<a href="">可选绑定<code>待添加链接</code></a>。</p>
|
||||
<p><em>condition</em>表达式的值的类型必须遵循<code>LogicValue</code>协议。同时,<em>condition</em>表达式也可以使用可选绑定,请参考<a href="">可选绑定<code>待添加链接</code></a>。</p>
|
||||
<blockquote>
|
||||
<p>GRAMMAR OF A WHILE STATEMENT</p>
|
||||
<p><em>while-statement</em> → <strong>while</strong> <a href="https://developer.apple.com/library/prerelease/ios/documentation/Swift/Conceptual/Swift_Programming_Language/Statements.html#//apple_ref/swift/grammar/while-condition" target="_blank"><em>while-condition</em></a> <a href="https://developer.apple.com/library/prerelease/ios/documentation/Swift/Conceptual/Swift_Programming_Language/Declarations.html#//apple_ref/swift/grammar/code-block" target="_blank"><em>code-block</em></a></p>
|
||||
@ -689,7 +689,7 @@
|
||||
</li>
|
||||
</ol>
|
||||
<p>由于<em>condition</em>表达式的值是在<em>statements</em>表达式执行后才计算出,因此<em>do-while</em>语句中的<em>statements</em>至少会被执行一次。</p>
|
||||
<p><em>condition</em>表达式的值的类型必须符合<code>LogicValue</code>协议。同时,<em>condition</em>表达式也可以使用可选绑定,请参考<a href="">可选绑定<code>待添加链接</code></a>。</p>
|
||||
<p><em>condition</em>表达式的值的类型必须遵循<code>LogicValue</code>协议。同时,<em>condition</em>表达式也可以使用可选绑定,请参考<a href="">可选绑定<code>待添加链接</code></a>。</p>
|
||||
<blockquote>
|
||||
<p>GRAMMAR OF A DO-WHILE STATEMENT</p>
|
||||
<p><em>do-while-statement</em> → <strong>do</strong> <a href="https://developer.apple.com/library/prerelease/ios/documentation/Swift/Conceptual/Swift_Programming_Language/Declarations.html#//apple_ref/swift/grammar/code-block" target="_blank"><em>code-block</em></a> <strong>while</strong> <a href="https://developer.apple.com/library/prerelease/ios/documentation/Swift/Conceptual/Swift_Programming_Language/Statements.html#//apple_ref/swift/grammar/while-condition" target="_blank"><em>while-condition</em></a> </p>
|
||||
@ -727,7 +727,7 @@ else {
|
||||
`statements to execute if both conditions are false`
|
||||
}
|
||||
</code></pre>
|
||||
<p><code>if</code>语句中条件的值的类型必须符合<code>LogicValue</code>协议。同时,条件也可以使用可选绑定,请参考<a href="">可选绑定<code>待添加链接</code></a>。</p>
|
||||
<p><code>if</code>语句中条件的值的类型必须遵循<code>LogicValue</code>协议。同时,条件也可以使用可选绑定,请参考<a href="">可选绑定<code>待添加链接</code></a>。</p>
|
||||
<blockquote>
|
||||
<p>GRAMMAR OF AN IF STATEMENT</p>
|
||||
<p><em>if-statement</em> → <strong>if</strong> <a href="https://developer.apple.com/library/prerelease/ios/documentation/Swift/Conceptual/Swift_Programming_Language/Statements.html#//apple_ref/swift/grammar/if-condition" target="_blank"><em>if-condition</em></a> <a href="https://developer.apple.com/library/prerelease/ios/documentation/Swift/Conceptual/Swift_Programming_Language/Declarations.html#//apple_ref/swift/grammar/code-block" target="_blank"><em>code-block</em></a> <a href="https://developer.apple.com/library/prerelease/ios/documentation/Swift/Conceptual/Swift_Programming_Language/Statements.html#//apple_ref/swift/grammar/else-clause" target="_blank"><em>else-clause</em></a> <em>opt</em></p>
|
||||
|
||||
@ -46,7 +46,7 @@
|
||||
|
||||
|
||||
|
||||
<div class="book" data-level="3" data-basepath=".." data-revision="1402402017737">
|
||||
<div class="book" data-level="3" data-basepath=".." data-revision="1402440614492">
|
||||
<div class="book-header">
|
||||
<!-- Actions Left -->
|
||||
<a href="#" class="btn pull-left toggle-summary" aria-label="Toggle summary"><i class="fa fa-align-justify"></i></a>
|
||||
|
||||
@ -44,7 +44,7 @@
|
||||
|
||||
|
||||
|
||||
<div class="book" data-level="0" data-basepath="." data-revision="1402402017737">
|
||||
<div class="book" data-level="0" data-basepath="." data-revision="1402440614492">
|
||||
<div class="book-header">
|
||||
<!-- Actions Left -->
|
||||
<a href="#" class="btn pull-left toggle-summary" aria-label="Toggle summary"><i class="fa fa-align-justify"></i></a>
|
||||
|
||||
@ -1,5 +1,5 @@
|
||||
CACHE MANIFEST
|
||||
# Revision 1402402017738
|
||||
# Revision 1402440614493
|
||||
|
||||
CACHE:
|
||||
index.html
|
||||
@ -26,10 +26,10 @@ chapter2/17_Optional_Chaining.html
|
||||
chapter2/18_Type_Casting.html
|
||||
chapter2/19_Nested_Types.html
|
||||
chapter2/20_Extensions.html
|
||||
chapter2/22_Generics.html
|
||||
chapter2/21_Protocols.html
|
||||
chapter2/23_Advanced_Operators.html
|
||||
chapter2/22_Generics.html
|
||||
chapter2/chapter2.html
|
||||
chapter2/23_Advanced_Operators.html
|
||||
chapter3/06_Attributes.html
|
||||
chapter3/01_About_the_Language_Reference.html
|
||||
chapter3/03_Types.html
|
||||
@ -38,9 +38,9 @@ chapter3/05_Declarations.html
|
||||
chapter3/02_Lexical_Structure.html
|
||||
chapter3/07_Patterns.html
|
||||
chapter3/08_Generic_Parameters_and_Arguments.html
|
||||
chapter3/09_Summary_of_the_Grammar.html
|
||||
chapter3/10_Statements.html
|
||||
chapter3/chapter3.html
|
||||
chapter3/09_Summary_of_the_Grammar.html
|
||||
gitbook/app.js
|
||||
gitbook/fonts/anonymouspro/400.woff
|
||||
gitbook/fonts/anonymouspro/400i.woff
|
||||
|
||||
File diff suppressed because one or more lines are too long
Reference in New Issue
Block a user