Swift 2.0 到底「新」在哪?

【编者按】2015年6月,一年一度的苹果 WWDC 大会如期而至,在大会上苹果发布了 Swift 2.0,引入了很多新的特性,以帮助开发者更快、更简单地构建应用。本篇文章作者是 Maxime defauw ,本文中 Maxime 向大家简要介绍 Swift 2.0 中值得注意的新特性。本文系 OneAPM 工程师编译整理。

一年前,苹果推出了面向 iOS 和 OS X 的全新编程语言—— Swift。当听到它发布的时候,像千千万万 iOS 开发者那样,笔者的内心激动无比。正如宣传所说的那样,作为一门快速、安全的编程语言,Swift 已经成长为最流行的编程语言之一。一年之后,苹果不负众望,在2015年的 WWDC 会议中推出了 Swift 2.0。作者有幸去了现场,所以在这里向大家介绍一下 Swift 2.0 的新特性。

「今年,我们将借助 Swift 2.0 乘风破浪。我们认为 Swift 即将成为最大的编程语言,并且成为下个二十年最不可或缺的应用和系统编程语言。任何人在任何地方都能使用 Swift 」,苹果公司软件工程副总裁 Craig Federighi 说道。

Swift 2.0 到底「新」在哪?

在 WWDC 大会上,苹果测量了分贝的新功能普及性。会议中两次最大的掌声,一次是苹果宣布 Xcode 7 支持 UI 测试,另一次则是 Swift 的开源。如果你错过 WWDC 的主题演讲,或者最近生活得压力山大,那么请你再确认一下,你没有看错:Swift 真的开源了。这可是件大事!下半年,苹果还将公开发布在 OSI 标准许可下的 Swift 的源代码,包括编译器和标准库。苹果也将开放 Linux 的源代码端口,开发者将能够促进语言的发展,并在 Linux 上编写 Swift 程序。由此看出,苹果鼓励开发者进一步推动 Swift 的发展。

随着这一令人振奋的消息的发布,Swift 2.0 涵盖了更多新的功能,如升级的错误处理、协议扩展和可用性检查。下面我们就来看看这些新特性。

错误处理

程序总会出错。当函数出现问题时,如果能找出哪里出错,便能理解为什么会出现异常。Swift 1.0 版本缺乏有效的错误处理机制。在 Swift 2.0 中,开发者可以利用 try / throw / catch 关键字,建立异常处理模式。

假设你正在加入汽车引擎模型。引擎可能由于某些原因导致失败:

  • 没油;

  • 漏油;

  • 低电量。

在 Swift 中,错误可以看做符合 ErrorType 协议的类型值。在这种情况下,你可以创建立一个符合 ErrorType 的枚举模型来表示错误情形:

enum CarEngineErrors: ErrorType {
    case NoFuel
    case OilLeak
    case LowBattery
}

构造一个可以抛出异常的函数,在声明中使用 throws 关键字,如下例所示:

func checkEngine() throws {
}

函数中抛出错误,你可以使用 throw 声明。下例代码演示了如何对引擎错误进行简单检查:

let fuelReserve = 20.0
let oilOk = true
let batteryReserve = 0.0
 
func checkEngine() throws {
    guard fuelReserve > 0.0 else {
        throw CarEngineErrors.NoFuel
    }
    
    guard oilOk else {
        throw CarEngineErrors.OilLeak
    }
    
    guard batteryReserve > 0.0 else {
        throw CarEngineErrors.LowBattery
    }
}

guard 关键词是 Swift 2.0 为了增强控制流首次引用的。当执行到 guard 语句时,首先会检查条件语句。如果条件为 false,则 else 部分会被执行。以上代码中,如果没有条件符合,函数将会抛出异常。

为了调用抛出函数,需要把 try 关键字放在函数调用之前。

func startEngine() {
    try checkEngine()
}

如果在 Playgrounds 中写入以上代码,在处理异常之前已经出现错误。Swift 里的错误处理机制,需要使用 do-catch 语句来抓取异常并进行恰当处理。

下面的函数指定了捕获异常后的响应:

func startEngine() {
    do {
        try checkEngine()
        print("Engine started", appendNewline: true)
    } catch CarEngineErrors.NoFuel {
        print("No Fuel!")
    } catch CarEngineErrors.OilLeak {
        print("Oil Leak!")
    } catch CarEngineErrors.LowBattery {
        print("Low Battery!")
    } catch {
        // Default
        print("Unknown reason!")
    }
}

每个 catch 从句都匹配特定的错误,并且指定相关错误的响应机制。在上面的例子中,batteryReserve 变量被置为0,这种情况下调用 startEngine()将会抛出 .LowBattery 异常。

假如把 batteryReserve 重置为 1.0,这样就没有异常抛出,窗口打印「Engine started」的提示信息。

类似于 switch 语句,Swift 2 的错误处理机制是完备的,你需要考虑到所有可能的错误情况。所以我们需要包含一个不指定类型的 catch 从句。

如果需要了解更多 Swift 的错误处理机制,推荐大家参考 Apple Documentation。

println()函数缺席

在作者写这篇介绍时,他注意到 println()函数的缺席。在 Swift 2.0 中,我们只需 print()函数便能打印到输出窗口。苹果公司将 println()和 print()函数合二为一。如果你想隔行输出,可以将 appendNewline 参数设为 true。如下面代码所示:

print("Engine started", appendNewline: true)

协议扩展

在老版 Swift 中,你可以使用扩展为现有的类、结构或枚举添加新功能。Swift 2.0 允许开发者应用扩展到协议类型。随着协议的扩展,你可以通过添加一个特定协议,为所有类添加函数或属性,也便于扩展协议的功能。

如下例所示,创建一个新协议并命名为 Awesome。该协议可以由任何能返回特定对象的 awesomeness 指数百分比的类型来实现。

protocol Awesome {
    func awesomenessPercentage() -> Float
}

现在声明两个遵守新协议的类。每个类都实现了 Awesome 协议的指定方法:

class Dog: Awesome {
    var age: Int!
    func awesomenessPercentage() -> Float {
        return 0.85
    }
}
 
class Cat: Awesome {
    var age: Int!
    func awesomenessPercentage() -> Float {
        return 0.45
    }
}
 
let dog = Dog()
dog.awesomenessPercentage()
 
let cat = Cat()
cat.awesomenessPercentage()

在 Playground 中初始化该类并调用 awesomenessPercentage()方法,会看到如下输出:

Swift 2.0 到底「新」在哪?

如果你想补充一个 awesomenessIndex 属性来扩展 Awesom 协议,那么可以使用 awesomenessPercentage 方法的结果来计算 awesomeness 值。编码如下:

extension Awesome {
    var awesomenessIndex: Int {
        get {
            return Int(awesomenessPercentage() * 100)
        }
    }
}

在协议中创建扩展,所有遵循 Awesome 协议的类都能访问 awesomenessIndex 属性。

Swift 2.0 到底「新」在哪?

的确很炫酷,是吧?

可用性检查

开发者都知道,构建应用需要时时与不同 iOS 版本做斗争。你总是希望使用最新版的 API,但有时应用旧版本的 iOS 上运行时容易出错,这可能会导致 Bug。在 Swift 2.0 之前,没有标准方式来进行可用性检查。比如:NSURLQueryItem 类在 iOS 8 上才可用,如果在 iOS 以前的版本中使用则会出错,甚至会导致应用崩溃。为了避免这种错误,你可以按照以下代码执行可用性检查:

if NSClassFromString("NSURLQueryItem") != nil {
    // iOS 8 or up
} else{
    // Earlier iOS versions
}

这是检查类是否存在的一种方式。从 Swift 2 开始支持 API 在不同版本下的可用性检查。你可以简单定义一个可用性条件,所以相应的代码块只能在特定的 iOS 版本下执行,举例如下:

if #available(iOS 8, *) {
    // iOS 8 or up
    let queryItem = NSURLQueryItem()
    
} else {
    // Earlier iOS versions
    
}

do-while 更改为 repeat-while

经典的 do-while 循环现改名为 repeat-while,请参考下例:

var i = 0
repeat {
    i++
    print(i)
} while i < 10

总结

希望大家能喜欢这篇关于 Swift 2.0 的介绍。还有很多内容没有涵盖到,比如 Markdown 格式的注释等。更多详情可以参考 this WWDC video。写到这儿,很多公司还在使用 Objective-C 作为构建 iOS 应用的主要编程语言,很可能你也是。但作者仍坚信 Swift 的发展前景更为广阔。事实上,2015年 WWDC上所有重要会议都在使用 Swift,如果你还没有学习 Swift,是时候采取行动了!

你可以在此下载本篇文章的 Playground 文件。确保使用 Xcode 7运行的代码,这是唯一支持 Swift 2.0 的 Xcode 版本。Xcode 7 目前仍处于测试阶段。你可以从苹果官网上下载。

原文地址:What’s New in Swift 2.0: A Brief Introduction

本文系 OneAPM 工程师编译整理。想阅读更多技术文章,请访问 OneAPM 官方博客


OneAPM 官方技术专栏
OneAPM 官方技术分享平台

Software makes the world run. OneAPM makes the software run.

11.4k 声望
509 粉丝
0 条评论
推荐阅读
Cloud Alert 实现告警智能降噪,成功规避告警风暴
睿象云前段时间发表了一篇《 Zabbix 实现电话、邮件、微信告警通知的实践分享》的技术文章。它帮助我们非常轻松地支持了各种告警通知方式,但是存在一个严重的问题,我们经常接到各种相类似或者相关联告警,短信...

OneAPM蓝海讯通1阅读 2.1k

iOSer 年度总结|晋升的逻辑是什么
2022年是疫情3年的一个“小尾巴”,但它一点也不小,因为它是3年内大家感受最深的一年,也是影响最大的一年。身边同事们换工作、周围见闻都可以印证这个结论。

杭城小刘6阅读 1.8k

封面图
这一次,解决Flutter Dialog的各种痛点!
4.0版本做了重大调整,迁移请参照: SmartDialog 3.x 迁移 4.0本文内容已更新,文中内容及其代码皆为4.0用法前言Q:你一生中闻过最臭的东西,是什么?A:我那早已腐烂的梦。兄弟萌!!!我又来了!这次,我能自信...

小呆呆6661阅读 3.4k

封面图
iOS 健康共享失败如何解决
您要开始与之共享的对象必须已经连同他们的 iCloud 账户邮箱一起保存在您的“通讯录”中(iCloud 账户邮箱即 iCloud 账户绑定的邮箱信息,不是强制要求 @iCloud.com 邮箱)。

岚哲阅读 7.1k

Flutter 让你的Dialog脱胎换骨吧!(Attach,Dialog,Loading,Toast)
4.0版本做了重大调整,迁移请参照: SmartDialog 3.x 迁移 4.0本文内容已更新,文中内容及其代码皆为4.0用法前言Q:你一生中闻过最臭的东西,是什么?A:我那早已腐烂的梦。兄弟萌!!!我又来了!这次,我能自信...

小呆呆6662阅读 2.3k

封面图
网易云音乐开源全链路埋点方案-曙光埋点(dawn)
网易云音乐开源了曙光埋点 dawn,一个跨多端的全链路埋点解决方案,旨在构造一个完美的数据理想国。曙光埋点创造性的提出了埋点虚拟树(VTree),并在此基础上实现了诸多能力,解决大前端侧埋点困难、精度差、不...

云音乐技术团队2阅读 311

封面图
探究 iOS 内存问题
本文从 Tagged Pointer、objc 源码、dealloc 原理、AutoreleasePool 原理、野指针探究等技术点展开聊了聊 iOS 内存相关问题。

杭城小刘1阅读 1.8k

封面图

Software makes the world run. OneAPM makes the software run.

11.4k 声望
509 粉丝
宣传栏