校正了部分标点、语句

This commit is contained in:
littlekok
2014-08-29 19:49:13 +08:00
parent 88cf8370b8
commit b42ceb0e5c

View File

@ -11,25 +11,25 @@
- [内嵌可选类型](#nested-optional)
- [提供一个默认值](#provide-default)
可选类型是Swift中新引入的功能很强大这篇博文我们将讨论在Swift里如何通过可选类型来保证强类型的安全性。我们创建一个Objective-C API的Swift版本作为例子但实际上Swift本身并不需要这样的API。
可选类型是Swift中新引入的功能很强大。在这篇博文里讨论的,是在Swift里如何通过可选类型来保证强类型的安全性。作为例子,我们创建一个Objective-C API的Swift版本但实际上Swift本身并不需要这样的API。
<a name="#add-function"></a>
#### 为Dictionary增加objectsForKeys函数
在Objective-C中```NSDictionary```有一个方法```-objectsForKeys:NoFoundMarker:```, 这个方法需要一个键值值的```NSArray```数组作为参数,同时返回一个包含相关值的数组。文档里我们可以看出:"返回数组中的第N个值和参数输入数组中的第N个值相对应",那如果有某个键值在字典里不存在呢?于是就```notFoundMarker```作为返回提示比如第三个键值没有找到,那么在返回数组中第三个值就是```notFoundMarker```,而不是字典中的第三个值,但是这个值只是提醒原字典中没有找到,但在返回数组中该元素存在,且用```notFoundMarker```作为占位符,因为不能直接使用所以在Foundation框架中有个专门的类处理这个情况```NSNull```。
在Objective-C中```NSDictionary```有一个方法```-objectsForKeys:NoFoundMarker:```, 这个方法需要一个```NSArray```数组作为键值参数,然后返回一个包含相关值的数组。文档里写到:"返回数组中的第N个值和输入数组中的第N个值相对应",那如果有某个键值在字典里不存在呢?于是就有了```notFoundMarker```作为返回提示比如第三个键值没有找到,那么在返回数组中第三个值就是这个```notFoundMarker```,而不是字典中的第三个值,但是这个值只是用来提醒原字典中没有找到对应值,但在返回数组中该元素存在,且用```notFoundMarker```作为占位符,因为这个对象不能直接使用所以在Foundation框架中有个专门的类处理这个情况```NSNull```。
在Swift中```Dictionary```类没有```objectsForKeys```的函数,为了说明问题,我们动手加一个,并且使其成为操作字典值的通用方法。我们可以使用```extension```来实现:
在Swift中```Dictionary```类没有类似```objectsForKeys```的函数,为了说明问题,我们动手加一个,并且使其成为操作字典值的通用方法。我们可以用```extension```来实现:
```
extension Dictionary{
func valuesForKeys(keys:[K], notFoundMarker: V )->[V]{
//接下来实现
//具体实现代码后面会写到
}
}
```
以上就是我们实现的Swift版本这个Objective-C版本有很大区别 在Swift中因为其强类型的原因限制了返回的结果数组只能包含单一类型的元素所以我们不能放```NSNull```在字符串数组中但是Swift有更好的选择我们可以返回一个可选类型数据我们所有的值都封包在可选类型中,而不是```NSNull```, 我们只用```nil```即可
以上就是我们实现的Swift版本这个Objective-C版本有很大区别在Swift中因为其强类型的原因限制了返回的结果数组只能包含单一类型的元素所以我们不能放```NSNull```在字符串数组中但是Swift有更好的选择我们可以返回一个可选类型数据我们所有的值都封包在可选类型中,而不是```NSNull```, 我们只用```nil```就可以了
```
@ -48,7 +48,7 @@ extension Dictionary{
<a name="#easy-function"></a>
#### Swift中更简便的方法
小伙伴们可能会问为什么Swift中不需要实现这么一个API呢其实其有更简单的实现如下代码所示
小伙伴们可能会问为什么Swift中不需要实现这么一个API呢其实其有更简单的实现如下代码所示:
```
extension Dictionary {
@ -58,14 +58,21 @@ extension Dictionary {
}
```
上述方式实现的功能和最开始的方法实现的功能相同,虽然核心的功能是封装了```map```的调用这个例子也说明了为什么Swift没有提供轻量级的API接口因为小伙伴们可以通过简单的调用```map```就可以实现。
上述方式实现的功能和最开始的方法实现的功能相同,虽然核心的功能是封装了```map```的调用这个例子也说明了为什么Swift没有提供轻量级的API接口因为小伙伴们简单的调用```map```就可以实现。
接下来,我们实验几个例子:
```
var dic: Dictionary = [ "1": 2, "3":3, "4":5 ]
var t = dic.valuesForKeys(["1", "4"]) //结果为:[Optional(2), Optional(5)]
t = dic.valuesForKeys([])//结果为:[]
var t = dic.valuesForKeys(["1", "4"])
//结果为:[Optional(2), Optional(5)]
var t = dict.valuesForKeys(["3", "9"])
// 结果为:[Optional(3), nil]
t = dic.valuesForKeys([])
//结果为:[]
```
<a name="#nested-optional"></a>
@ -75,8 +82,16 @@ t = dic.valuesForKeys([])//结果为:[]
```
var dic: Dictionary = [ "1": 2, "3":3, "4":5 ]
var t = dic.valuesForKeys(["1", "4"]).last //结果为Optional(Optional(5))
t = dic.valuesForKeys([])//结果为:Optional(nil)
// Optional(Optional("Ching"))
var t = dict.valuesForKeys(["3", "9"]).last
// 结果为Optional(nil)
var t = dict.valuesForKeys([]).last
// 结果为nil
```
小伙伴们立马迷糊了,为什么会出现两层包含的可选类型呢?,特别对第二种情况的```Optional(nil)```,这是什么节奏?
@ -105,7 +120,7 @@ var last:T? { get }
<a name="#provide-default"></a>
#### 提供一个默认值
进一步封装,如果我字典中的某个或某些元素不存在,我们想提供一个默认值怎么办呢?很简单实现
进一步封装,如果我字典中的某个或某些元素不存在,我们想提供一个默认值怎么办呢?实现方法很简单:
```
extension Dictionary {
@ -122,6 +137,6 @@ dict.valuesForKeys(["1", "5"], notFoundMarker: "Anonymous")
和Objective-C相比其需要占位符来达到占位的目的但是Swift却已经从语言类型系统的层面原生的支持了这种用法同时提供了丰富的语法功能。这就是Swift可选类型的强大之处。同时注意上述例子中用到了空合运算符```??```。
-----------------
本章节不是老码的原创,老码认真的阅读了苹果的官方博客,自己的练习总结,如果小伙伴们费了吃奶的劲还是看不懂,请找度娘谷歌还是看不懂请到老码[官方微博](http://weibo.com/u/5241713117)咆哮。
本章节不是老码的原创,老码认真的阅读了苹果的官方博客,自己的练习总结,如果小伙伴们费了吃奶的劲还是看不懂,请找度娘谷歌还是看不懂请到老码[官方微博](http://weibo.com/u/5241713117)咆哮。
##### 本文由翻译自Apple Swift Blog [Optionals Case Study: valuesForKeys](https://developer.apple.com/swift/blog/?id=12)