2

作者:Erica Sadun,原文链接,原文日期:2016-03-03
译者:Crystal Sun;校对:shanks;定稿:Cee

今天,苹果接受了三大重要的内部驱动的提议(有些提议内容稍作了修改):

由 Swift 核心团队开发的,这三大提议彻底确定了 Swift 语言的特点,开发者如何使用 Swift 继续前进。

API 设计指南(SE-0023)最引人注目,可以说是最棒的设计指南的典型范例,也是苹果公司的一贯风格。里面大部分内容都浅显易懂,很多建议非常有帮助,而有一部分内容我稍微有些个人的看法。作为开发者,你可以尽可能的提出欢迎或者批评。

自动转换的项目(SE-0005)已经放弃了去掉 API 名字前面的 NS 前缀的工作(暂时放弃了,修改后的提议会作为一个独单的提议提出来)。采用 API 指南将 Cocoa 的特色带进 Swift 的世界里。阅读评论,可以获知这些 API 将会如何转换,也包括 Swift 2 到 Swift 3 的项目工程。

提议的重要部分就是要去掉 Foundation API 里的 “NS” 前缀,这次改名被认为是有问题的,考虑到了好几个原因,最经常提及的原因就是 Swift 中很多 Foundation 的参考语义属性同 Swift 标准库中的值语义互相矛盾冲突。 去 “NS” 前缀提议苹果官方目前没有接受,修改后的提议将会作为一个单独的提议重新再次提出来,同时会考虑收到的反馈。

最后,标准库更新(SE-0006)确立了 Swift 看起来如何,标准库中的方法如何与最新的 API 指南协调一致。

提议中的这些改变会造成 Swift 代码大规模的崩坏,需要一个迁移工具将 Swift 2 的代码顺利迁移成 Swift 3 代码。提议中不同的 API 将是迁移的首要信息来源。另外,在语言允许的情况下,库里仍然保留了旧的名字,同时用 rename 关键字作为弃用符号标注出来,帮助编译器能够生成正确的错误信息,弹出如何修改的信息。

在接受提议时,苹果提到了两个重要的改变:

提议中大部分修改都是与 Swift API 设计指南(SE-0023)有关的,特别是:

  • 标准库中使用第一个参数的标签

  • 小写枚举的名称,包括 .some(x) 和 .none

第一个参数的标签从 Swift 1 进化到 Swift 2 时更像是 Objective-C 语言风格,到了 Swift 3 则又更像是 Swift 语言风格了。目前已经处于纯 C 和纯 Objective-C 之间了,希望相对于两次这次能找到平衡。

例如:

  • func advancedBy(n: Distance, limit: Self) -> Self

  • func advanced(by n: Distance, limit: Self) -> Self

  • func distanceTo(end: Self) -> Distance

  • func distance(to end: Self) -> Distance

枚举将和其他静态成员一样,命名规则是小写字母开头,使用驼峰命名法。

更多扩充修改的列表可以更新的提议中找到。

本文由 SwiftGG 翻译组翻译,已经获得作者翻译授权,最新文章请访问 http://swift.gg


SwiftGG翻译组
1.6k 声望957 粉丝

走心的 Swift 翻译组