首页 >Swift

Swift2.2新特性前瞻

2016-02-19 06:11 编辑: 令狐葱 分类:Swift 来源:没故事的卓同学 投稿

本文是投稿文章,作者:@没故事的卓同学

根据苹果的公开信息,Swift2.2将于今年春季发布,3.0将于今年年末发布。在苹果开源了swift的同时,也把开发计划开源了出来:swift-evolution

根据文档描述,2.2主要是bug修复,性能提升,在不影响原先代码使用的一些小改进。预计年底发布的3.0将会是一个大的改动(包括一些常见api的重命名),也将在2.2中提前给出一些提示,好让开发者尽早开始迁移代码。

现在我整理一下文档中一些明确的2.2中将会有的变化。

允许更多的关键字用做参数名

好的参数名对于提高代码可读性很重要。在swift中很多关键字比如in,repeat,defer都不能用做参数名。

225849-f2311de34c971d9e.png

2.2中,除了少数修饰参数的关键字外都将允许用作参数名。

为Tuples增加对比操作符

当前,Tuples的数据不能使用==操作符:

225849-7171888342fb5180.png

2.2中将支持Tuples

关联已存在类型时,不再使用typealias

typealias现在有两个用处:

  • 为一个已经存在的类型取个别名

  • 在协议中作为一个类型的占位名称

代码如下:

225849-a2d5dafe437986ec.png

这是两种完全不同的用法,不应该用一样的关键字。

2.2中将第一种情况时,启用新的关键字associatedtype

函数签名将包括参数名

一个函数有相同的函数名,参数名不同有多个重载很常见。当有多个重载时,在调用时能够通过参数名来区别。但是在获取类型时,却不包括参数名。

举例UIView中有这么几个方法:

225849-f4a4ce78e8770ffb.png

使用时可以通过参数名区分:

225849-81d1cd247961b154.png

但是这样使用时却会报错:

let fn = someView.insertSubview // ambiguous: could be any of the three methods

2.2中将会解决这个问题

一个新的方法生成selector

现在为了生成OC下使用的selector只能使用字符串生成,没有类型检查,很容易造成失误。

将提供一个#selector()方法生成selector,如下:

let sel = #selector(UIView.insertSubview(_:at:)) // produces the Selector "insertSubview:atIndex:"

增加#if swift 语法判断当前swift版本

使用如下:

225849-5cae13ffbd337dd3.png

搜索CocoaChina微信公众号:CocoaChina
微信扫一扫
订阅每日移动开发及APP推广热点资讯
公众号:
CocoaChina
我要投稿   收藏文章
上一篇:使用Web浏览器编译Swift代码,及Swift中的泛型
我来说两句
发表评论
您还没有登录!请登录注册
所有评论(0

综合评论

相关帖子

sina weixin mail 回到顶部