make gitbook
This commit is contained in:
169
chapter2/12_Subscripts.html
Executable file → Normal file
169
chapter2/12_Subscripts.html
Executable file → Normal file
@ -21,7 +21,7 @@
|
||||
<link rel="prev" href="../chapter2/11_Methods.html" />
|
||||
|
||||
|
||||
<meta property="og:title" content="附属脚本 | The Swift Programming Language 中文版">
|
||||
<meta property="og:title" content="下标脚本 | The Swift Programming Language 中文版">
|
||||
<meta property="og:site_name" content="The Swift Programming Language 中文版">
|
||||
<meta property="og:type" content="book">
|
||||
<meta property="og:locale" content="en_US">
|
||||
@ -46,7 +46,7 @@
|
||||
|
||||
|
||||
|
||||
<div class="book" data-level="2.12" data-basepath=".." data-revision="1402677669306">
|
||||
<div class="book" data-level="2.12" data-basepath=".." data-revision="1402750255397">
|
||||
<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>
|
||||
@ -268,7 +268,7 @@
|
||||
<li class="chapter " data-level="2.12" data-path="chapter2/12_Subscripts.html">
|
||||
|
||||
<a href="../chapter2/12_Subscripts.html">
|
||||
<i class="fa fa-check"></i> <b>2.12.</b> 附属脚本
|
||||
<i class="fa fa-check"></i> <b>2.12.</b> 下标脚本
|
||||
</a>
|
||||
|
||||
|
||||
@ -520,7 +520,7 @@
|
||||
|
||||
<a href="../chapter2/11_Methods.html" title="方法" class="chapter done " data-progress="2.11" style="left: 18.42105263157895%;"></a>
|
||||
|
||||
<a href="../chapter2/12_Subscripts.html" title="附属脚本" class="chapter done " data-progress="2.12" style="left: 21.05263157894737%;"></a>
|
||||
<a href="../chapter2/12_Subscripts.html" title="下标脚本" class="chapter done " data-progress="2.12" style="left: 21.05263157894737%;"></a>
|
||||
|
||||
<a href="../chapter2/13_Inheritance.html" title="继承" class="chapter " data-progress="2.13" style="left: 23.68421052631579%;"></a>
|
||||
|
||||
@ -587,82 +587,132 @@
|
||||
|
||||
<div class="page-inner">
|
||||
|
||||
<section class="normal" id="section-gitbook_109">
|
||||
<section class="normal" id="section-gitbook_53">
|
||||
|
||||
<blockquote>
|
||||
<p>翻译:siemenliu</p>
|
||||
<p>校对:zq54zquan</p>
|
||||
<p>翻译:siemenliu<br>校对:zq54zquan </p>
|
||||
</blockquote>
|
||||
<h1 id="-subscripts-">附属脚本(Subscripts)</h1>
|
||||
<h1 id="-subscripts-">下标脚本(Subscripts)</h1>
|
||||
<hr>
|
||||
<p>本页包含内容:</p>
|
||||
<ul>
|
||||
<li><a href="#subscript_syntax">附属脚本语法</a></li>
|
||||
<li><a href="#subscript_usage">附属脚本用法</a></li>
|
||||
<li><a href="#subscript_options">附属脚本选项</a></li>
|
||||
<li><a href="#subscript_syntax">下标脚本语法</a></li>
|
||||
<li><a href="#subscript_usage">下标脚本用法</a></li>
|
||||
<li><a href="#subscript_options">下标脚本选项</a></li>
|
||||
</ul>
|
||||
<p><em>附属脚本</em> 可以定义在类(Class)、结构体(structure)和枚举(enumeration)这些目标中,可以认为是访问对象、集合或序列的快捷方式,不需要再调用实例的特定的赋值和访问方法。举例来说,用附属脚本访问一个数组(Array)实例中的元素可以这样写 <code>someArray[index]</code> ,访问字典(Dictionary)实例中的元素可以这样写 <code>someDictionary[key]</code>。</p>
|
||||
<p>对于同一个目标可以定义多个附属脚本,通过索引值类型的不同来进行重载,而且索引值的个数可以是多个。</p>
|
||||
<p><em>下标脚本</em> 可以定义在类(Class)、结构体(structure)和枚举(enumeration)这些目标中,可以认为是访问对象、集合或序列的快捷方式,不需要再调用实例的特定的赋值和访问方法。举例来说,用下标脚本访问一个数组(Array)实例中的元素可以这样写 <code>someArray[index]</code> ,访问字典(Dictionary)实例中的元素可以这样写 <code>someDictionary[key]</code>。</p>
|
||||
<p>对于同一个目标可以定义多个下标脚本,通过索引值类型的不同来进行重载,而且索引值的个数可以是多个。</p>
|
||||
<p><<<<<<< HEAD</p>
|
||||
<h1 id="-">> 译者:这里附属脚本重载在本小节中原文并没有任何演示 </h1>
|
||||
<blockquote>
|
||||
<p>译者:这里附属脚本重载在本小节中原文并没有任何演示</p>
|
||||
<p>译者:这里下标脚本重载在本小节中原文并没有任何演示</p>
|
||||
<blockquote>
|
||||
<blockquote>
|
||||
<blockquote>
|
||||
<blockquote>
|
||||
<blockquote>
|
||||
<blockquote>
|
||||
<p>a516af6a531a104ec88da0d236ecf389a5ec72af</p>
|
||||
</blockquote>
|
||||
</blockquote>
|
||||
</blockquote>
|
||||
</blockquote>
|
||||
</blockquote>
|
||||
</blockquote>
|
||||
</blockquote>
|
||||
<p><a name="subscript_syntax"></a></p>
|
||||
<h2 id="-">附属脚本语法</h2>
|
||||
<p>附属脚本允许你通过在实例后面的方括号中传入一个或者多个的索引值来对实例进行访问和赋值。语法类似于实例方法和计算型属性的混合。与定义实例方法类似,定义附属脚本使用<code>subscript</code>关键字,显式声明入参(一个或多个)和返回类型。与实例方法不同的是附属脚本可以设定为读写或只读。这种方式又有点像计算型属性的getter和setter:</p>
|
||||
<pre><code>subscript(index: Int) -> Int {
|
||||
<h2 id="-">下标脚本语法</h2>
|
||||
<p>下标脚本允许你通过在实例后面的方括号中传入一个或者多个的索引值来对实例进行访问和赋值。语法类似于实例方法和计算型属性的混合。与定义实例方法类似,定义下标脚本使用<code>subscript</code>关键字,显式声明入参(一个或多个)和返回类型。与实例方法不同的是下标脚本可以设定为读写或只读。这种方式又有点像计算型属性的getter和setter:</p>
|
||||
<pre><code class="lang-swift">subscript(index: Int) -> Int {
|
||||
get {
|
||||
// 返回与入参匹配的Int类型的值
|
||||
// 返回与入参匹配的Int类型的值
|
||||
}
|
||||
|
||||
set(newValue) {
|
||||
// 执行赋值操作
|
||||
// 执行赋值操作
|
||||
}
|
||||
}
|
||||
</code></pre><p><code>newValue</code>的类型必须和附属脚本定义的返回类型相同。与计算型属性相同的是set的入参声明<code>newValue</code>就算不写,在set代码块中依然可以使用默认的<code>newValue</code>这个变量来访问新赋的值。</p>
|
||||
</code></pre>
|
||||
<p><code>newValue</code>的类型必须和下标脚本定义的返回类型相同。与计算型属性相同的是set的入参声明<code>newValue</code>就算不写,在set代码块中依然可以使用默认的<code>newValue</code>这个变量来访问新赋的值。</p>
|
||||
<p>与只读计算型属性一样,可以直接将原本应该写在<code>get</code>代码块中的代码写在<code>subscript</code>中:</p>
|
||||
<pre><code>subscript(index: Int) -> Int {
|
||||
<pre><code class="lang-swift">subscript(index: Int) -> Int {
|
||||
// 返回与入参匹配的Int类型的值
|
||||
}
|
||||
</code></pre><p>下面代码演示了一个在<code>TimesTable</code>结构体中使用只读附属脚本的用法,该结构体用来展示传入整数的<em>n</em>倍。</p>
|
||||
<pre><code>struct TimesTable {
|
||||
</code></pre>
|
||||
<p>下面代码演示了一个在<code>TimesTable</code>结构体中使用只读下标脚本的用法,该结构体用来展示传入整数的<em>n</em>倍。</p>
|
||||
<pre><code class="lang-swift">struct TimesTable {
|
||||
let multiplier: Int
|
||||
subscript(index: Int) -> Int {
|
||||
return multiplier * index
|
||||
return multiplier * index
|
||||
}
|
||||
}
|
||||
let threeTimesTable = TimesTable(multiplier: 3)
|
||||
println("3的6倍是\(threeTimesTable[6])")
|
||||
// 输出 "3的6倍是18"
|
||||
</code></pre><p>在上例中,通过<code>TimesTable</code>结构体创建了一个用来表示索引值三倍的实例。数值<code>3</code>作为结构体<code>构造函数</code>入参初始化实例成员<code>multiplier</code>。</p>
|
||||
<p>你可以通过附属脚本来得到结果,比如<code>threeTimesTable[6]</code>。这条语句访问了<code>threeTimesTable</code>的第六个元素,返回<code>6</code>的<code>3</code>倍即<code>18</code>。</p>
|
||||
</code></pre>
|
||||
<p>在上例中,通过<code>TimesTable</code>结构体创建了一个用来表示索引值三倍的实例。数值<code>3</code>作为结构体<code>构造函数</code>入参初始化实例成员<code>multiplier</code>。</p>
|
||||
<p>你可以通过下标脚本来得到结果,比如<code>threeTimesTable[6]</code>。这条语句访问了<code>threeTimesTable</code>的第六个元素,返回<code>6</code>的<code>3</code>倍即<code>18</code>。</p>
|
||||
<p><<<<<<< HEAD</p>
|
||||
<blockquote>
|
||||
<p>注意: </p>
|
||||
<h1 id="-timestable-threetimestable-someindex-"><code>TimesTable</code>例子是基于一个固定的数学公式。它并不适合开放写权限来对<code>threeTimesTable[someIndex]</code>进行赋值操作,这也是为什么附属脚本只定义为只读的原因。 </h1>
|
||||
<p>注意:</p>
|
||||
<p><code>TimesTable</code>例子是基于一个固定的数学公式。它并不适合开放写权限来对<code>threeTimesTable[someIndex]</code>进行赋值操作,这也是为什么附属脚本只定义为只读的原因。</p>
|
||||
<p><code>TimesTable</code>例子是基于一个固定的数学公式。它并不适合开放写权限来对<code>threeTimesTable[someIndex]</code>进行赋值操作,这也是为什么下标脚本只定义为只读的原因。</p>
|
||||
<blockquote>
|
||||
<blockquote>
|
||||
<blockquote>
|
||||
<blockquote>
|
||||
<blockquote>
|
||||
<blockquote>
|
||||
<p>a516af6a531a104ec88da0d236ecf389a5ec72af</p>
|
||||
</blockquote>
|
||||
</blockquote>
|
||||
</blockquote>
|
||||
</blockquote>
|
||||
</blockquote>
|
||||
</blockquote>
|
||||
</blockquote>
|
||||
<p><a name="subscript_usage"></a></p>
|
||||
<h2 id="-">附属脚本用法</h2>
|
||||
<p>根据使用场景不同附属脚本也具有不同的含义。通常附属脚本是用来访问集合(collection),列表(list)或序列(sequence)中元素的快捷方式。你可以在你自己特定的类或结构体中自由的实现附属脚本来提供合适的功能。</p>
|
||||
<p>例如,Swift 的字典(Dictionary)实现了通过附属脚本来对其实例中存放的值进行存取操作。在附属脚本中使用和字典索引相同类型的值,并且把一个字典值类型的值赋值给这个附属脚本来为字典设值:</p>
|
||||
<pre><code>var numberOfLegs = ["spider": 8, "ant": 6, "cat": 4]
|
||||
<h2 id="-">下标脚本用法</h2>
|
||||
<p>根据使用场景不同下标脚本也具有不同的含义。通常下标脚本是用来访问集合(collection),列表(list)或序列(sequence)中元素的快捷方式。你可以在你自己特定的类或结构体中自由的实现下标脚本来提供合适的功能。</p>
|
||||
<p>例如,Swift 的字典(Dictionary)实现了通过下标脚本来对其实例中存放的值进行存取操作。在下标脚本中使用和字典索引相同类型的值,并且把一个字典值类型的值赋值给这个下标脚本来为字典设值:</p>
|
||||
<pre><code class="lang-swift">var numberOfLegs = ["spider": 8, "ant": 6, "cat": 4]
|
||||
numberOfLegs["bird"] = 2
|
||||
</code></pre><p>上例定义一个名为<code>numberOfLegs</code>的变量并用一个字典字面量初始化出了包含三对键值的字典实例。<code>numberOfLegs</code>的字典存放值类型推断为<code>Dictionary<String, Int></code>。字典实例创建完成之后通过附属脚本的方式将整型值<code>2</code>赋值到字典实例的索引为<code>bird</code>的位置中。</p>
|
||||
<p>更多关于字典(Dictionary)附属脚本的信息请参考<a href="../chapter2/04_Collection_Types.html">读取和修改字典</a></p>
|
||||
</code></pre>
|
||||
<p>上例定义一个名为<code>numberOfLegs</code>的变量并用一个字典字面量初始化出了包含三对键值的字典实例。<code>numberOfLegs</code>的字典存放值类型推断为<code>Dictionary<String, Int></code>。字典实例创建完成之后通过下标脚本的方式将整型值<code>2</code>赋值到字典实例的索引为<code>bird</code>的位置中。</p>
|
||||
<p>更多关于字典(Dictionary)下标脚本的信息请参考<a href="../chapter2/04_Collection_Types.html">读取和修改字典</a></p>
|
||||
<p><<<<<<< HEAD</p>
|
||||
<blockquote>
|
||||
<p>注意: </p>
|
||||
<h1 id="swift-get-int-numberoflegs-int-int-nil-nil-">Swift 中字典的附属脚本实现中,在<code>get</code>部分返回值是<code>Int?</code>,上例中的<code>numberOfLegs</code>字典通过附属脚本返回的是一个<code>Int?</code>或者说“可选的int”,不是每个字典的索引都能得到一个整型值,对于没有设过值的索引的访问返回的结果就是<code>nil</code>;同样想要从字典实例中删除某个索引下的值也只需要给这个索引赋值为<code>nil</code>即可。 </h1>
|
||||
<p>注意:</p>
|
||||
<p>Swift 中字典的附属脚本实现中,在<code>get</code>部分返回值是<code>Int?</code>,上例中的<code>numberOfLegs</code>字典通过附属脚本返回的是一个<code>Int?</code>或者说“可选的int”,不是每个字典的索引都能得到一个整型值,对于没有设过值的索引的访问返回的结果就是<code>nil</code>;同样想要从字典实例中删除某个索引下的值也只需要给这个索引赋值为<code>nil</code>即可。</p>
|
||||
<p>Swift 中字典的下标脚本实现中,在<code>get</code>部分返回值是<code>Int?</code>,上例中的<code>numberOfLegs</code>字典通过下标脚本返回的是一个<code>Int?</code>或者说“可选的int”,不是每个字典的索引都能得到一个整型值,对于没有设过值的索引的访问返回的结果就是<code>nil</code>;同样想要从字典实例中删除某个索引下的值也只需要给这个索引赋值为<code>nil</code>即可。</p>
|
||||
<blockquote>
|
||||
<blockquote>
|
||||
<blockquote>
|
||||
<blockquote>
|
||||
<blockquote>
|
||||
<blockquote>
|
||||
<p>a516af6a531a104ec88da0d236ecf389a5ec72af</p>
|
||||
</blockquote>
|
||||
</blockquote>
|
||||
</blockquote>
|
||||
</blockquote>
|
||||
</blockquote>
|
||||
</blockquote>
|
||||
</blockquote>
|
||||
<p><a name="subscript_options"></a></p>
|
||||
<h2 id="-">附属脚本选项</h2>
|
||||
<p>附属脚本允许任意数量的入参索引,并且每个入参类型也没有限制。附属脚本的返回值也可以是任何类型。附属脚本可以使用变量参数和可变参数,但使用写入读出(in-out)参数或给参数设置默认值都是不允许的。</p>
|
||||
<p>一个类或结构体可以根据自身需要提供多个附属脚本实现,在定义附属脚本时通过入参个类型进行区分,使用附属脚本时会自动匹配合适的附属脚本实现运行,这就是<em>附属脚本的重载</em>。</p>
|
||||
<p>一个附属脚本入参是最常见的情况,但只要有合适的场景也可以定义多个附属脚本入参。如下例定义了一个<code>Matrix</code>结构体,将呈现一个<code>Double</code>类型的二维矩阵。<code>Matrix</code>结构体的附属脚本需要两个整型参数:</p>
|
||||
<pre><code>struct Matrix {
|
||||
<h2 id="-">下标脚本选项</h2>
|
||||
<p>下标脚本允许任意数量的入参索引,并且每个入参类型也没有限制。下标脚本的返回值也可以是任何类型。下标脚本可以使用变量参数和可变参数,但使用写入读出(in-out)参数或给参数设置默认值都是不允许的。</p>
|
||||
<p>一个类或结构体可以根据自身需要提供多个下标脚本实现,在定义下标脚本时通过入参个类型进行区分,使用下标脚本时会自动匹配合适的下标脚本实现运行,这就是<em>下标脚本的重载</em>。</p>
|
||||
<p>一个下标脚本入参是最常见的情况,但只要有合适的场景也可以定义多个下标脚本入参。如下例定义了一个<code>Matrix</code>结构体,将呈现一个<code>Double</code>类型的二维矩阵。<code>Matrix</code>结构体的下标脚本需要两个整型参数:</p>
|
||||
<pre><code class="lang-swift">struct Matrix {
|
||||
let rows: Int, columns: Int
|
||||
var grid: Double[]
|
||||
init(rows: Int, columns: Int) {
|
||||
self.rows = rows
|
||||
self.columns = columns
|
||||
grid = Array(count: rows * columns, repeatedValue: 0.0)
|
||||
self.rows = rows
|
||||
self.columns = columns
|
||||
grid = Array(count: rows * columns, repeatedValue: 0.0)
|
||||
}
|
||||
func indexIsValidForRow(row: Int, column: Int) -> Bool {
|
||||
return row >= 0 && row < rows && column >= 0 && column < columns
|
||||
@ -678,30 +728,37 @@ numberOfLegs["bird"] = 2
|
||||
}
|
||||
}
|
||||
}
|
||||
</code></pre><p><code>Matrix</code>提供了一个两个入参的构造方法,入参分别是<code>rows</code>和<code>columns</code>,创建了一个足够容纳<code>rows * columns</code>个数的<code>Double</code>类型数组。为了存储,将数组的大小和数组每个元素初始值0.0,都传入数组的构造方法中来创建一个正确大小的新数组。关于数组的构造方法和析构方法请参考<a href="../chapter2/04_Collection_Types.html">创建并且构造一个数组</a>。</p>
|
||||
</code></pre>
|
||||
<p><code>Matrix</code>提供了一个两个入参的构造方法,入参分别是<code>rows</code>和<code>columns</code>,创建了一个足够容纳<code>rows * columns</code>个数的<code>Double</code>类型数组。为了存储,将数组的大小和数组每个元素初始值0.0,都传入数组的构造方法中来创建一个正确大小的新数组。关于数组的构造方法和析构方法请参考<a href="../chapter2/04_Collection_Types.html">创建并且构造一个数组</a>。</p>
|
||||
<p>你可以通过传入合适的<code>row</code>和<code>column</code>的数量来构造一个新的<code>Matrix</code>实例:</p>
|
||||
<pre><code>var matrix = Matrix(rows: 2, columns: 2)
|
||||
</code></pre><p>上例中创建了一个新的两行两列的<code>Matrix</code>实例。在阅读顺序从左上到右下的<code>Matrix</code>实例中的数组实例<code>grid</code>是矩阵二维数组的扁平化存储:</p>
|
||||
<pre><code>// 示意图
|
||||
<pre><code class="lang-swift">var matrix = Matrix(rows: 2, columns: 2)
|
||||
</code></pre>
|
||||
<p>上例中创建了一个新的两行两列的<code>Matrix</code>实例。在阅读顺序从左上到右下的<code>Matrix</code>实例中的数组实例<code>grid</code>是矩阵二维数组的扁平化存储:</p>
|
||||
<pre><code class="lang-swift">// 示意图
|
||||
grid = [0.0, 0.0, 0.0, 0.0]
|
||||
|
||||
col0 col1
|
||||
col0 col1
|
||||
row0 [0.0, 0.0,
|
||||
row1 0.0, 0.0]
|
||||
</code></pre><p>将值赋给带有<code>row</code>和<code>column</code>附属脚本的<code>matrix</code>实例表达式可以完成赋值操作,附属脚本入参使用逗号分割</p>
|
||||
<pre><code>matrix[0, 1] = 1.5
|
||||
row1 0.0, 0.0]
|
||||
</code></pre>
|
||||
<p>将值赋给带有<code>row</code>和<code>column</code>下标脚本的<code>matrix</code>实例表达式可以完成赋值操作,下标脚本入参使用逗号分割</p>
|
||||
<pre><code class="lang-swift">matrix[0, 1] = 1.5
|
||||
matrix[1, 0] = 3.2
|
||||
</code></pre><p>上面两条语句分别<code>让matrix</code>的右上值为 1.5,坐下值为 3.2:</p>
|
||||
<pre><code>[0.0, 1.5,
|
||||
</code></pre>
|
||||
<p>上面两条语句分别<code>让matrix</code>的右上值为 1.5,坐下值为 3.2:</p>
|
||||
<pre><code class="lang-swift">[0.0, 1.5,
|
||||
3.2, 0.0]
|
||||
</code></pre><p><code>Matrix</code>附属脚本的<code>getter</code>和<code>setter</code>中同时调用了附属脚本入参的<code>row</code>和<code>column</code>是否有效的判断。为了方便进行断言,<code>Matrix</code>包含了一个名为<code>indexIsValid</code>的成员方法,用来确认入参的<code>row</code>或<code>column</code>值是否会造成数组越界:</p>
|
||||
<pre><code>func indexIsValidForRow(row: Int, column: Int) -> Bool {
|
||||
</code></pre>
|
||||
<p><code>Matrix</code>下标脚本的<code>getter</code>和<code>setter</code>中同时调用了下标脚本入参的<code>row</code>和<code>column</code>是否有效的判断。为了方便进行断言,<code>Matrix</code>包含了一个名为<code>indexIsValid</code>的成员方法,用来确认入参的<code>row</code>或<code>column</code>值是否会造成数组越界:</p>
|
||||
<pre><code class="lang-swift">func indexIsValidForRow(row: Int, column: Int) -> Bool {
|
||||
return row >= 0 && row < rows && column >= 0 && column < columns
|
||||
}
|
||||
</code></pre><p>断言在附属脚本越界时触发:</p>
|
||||
<pre><code>let someValue = matrix[2, 2]
|
||||
</code></pre>
|
||||
<p>断言在下标脚本越界时触发:</p>
|
||||
<pre><code class="lang-swift">let someValue = matrix[2, 2]
|
||||
// 断言将会触发,因为 [2, 2] 已经超过了matrix的最大长度
|
||||
</code></pre>
|
||||
|
||||
|
||||
</section>
|
||||
|
||||
|
||||
Reference in New Issue
Block a user