Swift2.0:API可用性检查
Swift安全至上。除了
Swift2.0
引入的API
(应用程序编程接口)可用性检查之外,另外还新增一些非常棒的功能使得你的应用程序更加稳定。
每年Apple发布新的iOS重大更新之时,都将引入新的功能以及API
。但是它们并不能兼容先前的iOS
版本,导致你不得不谨慎对待这些新的API
。
设想应用程序的部署目标是iOS 8
(即只有iOS 8.0
以上的设备才能安装该程序),同时又要支持force touch
功能。对于低于iOS 9
版本的系统,有如下几种方式可以避免在iOS 8
系统下调用iOS 9
的API。
方式一:
// 以下为译者注解:
// respondsToSelector用来判断是否有以某个名字命名的方法(被封装在一个selector的对象里传递)
// 只有iOS 9 才有forceTouchCapability方法。
if traitCollection.respondsToSelector(Selector("forceTouchCapability")) {
// 检查ForceTouch是否可用 倘若可用 进行配置
if (traitCollection.forceTouchCapability == UIForceTouchCapability.Available) {
//配置 Force touch
}
}
方式二:
// 判断是否在iOS9能够正常工作
if NSProcessInfo().isOperatingSystemAtLeastVersion(NSOperatingSystemVersion(majorVersion: 9, minorVersion: 0, patchVersion: 0)) {
// 判断force touch 是否可用
if (traitCollection.forceTouchCapability == UIForceTouchCapability.Available) {
//配置 Force touch
}
}
以上这些解决方案的问题在于,你必须对所有检查都做到面面俱到.一旦你忘记检查新API的可用性,应用程序在旧版本中运行将导致崩溃。
不过,在Xcode7
和Swift2.0
下,以上两个范例均无法编译通过。你必须使用#available
关键字来进行API
可用性检查,如此就能解决编译器报错了。因此在Swift2.0
中你的代码应该这么写:
// 检查当前设备系统是否在iOS 9下可用
if #available(iOS 9.0,*){
// 可用情况下 才执行如下代码
if (traitCollection.forceTouchCapability == UIForceTouchCapability.Available) {
//configure force touch
}
}else {
// Fallback on earlier versions
}
Guard
此外,使用guard
来进行API
可用性检查也不失为一个良策。
func configureForceTouch() {
// guard只有满足条件下才进行下一步 不满足则直接跳出程序
guard #available(iOS 9.0, *) else {
return
}
if (traitCollection.forceTouchCapability == UIForceTouchCapability.Available) {
//configure force touch
}
}
例子中,倘若运行在设备上的系统版本小于等于iOS9.0
,那么函数就会直接跳出。
类和方法
当然我们还可对类和方法执行可用性检查。在这种情况下,必须使用@available
,而非#available
:
@available(iOS 9.0, *)
func configureForceTouch() {
if (traitCollection.forceTouchCapability == UIForceTouchCapability.Available) {
//configure force touch
}
}
}
平台的检查
你同样能够对除iOS
之外的平台进行检查。例如,检查应用程序是否支持在Mac OSX 10.10
版本以上运行。
if #available(iOS 9.0, OS X 10.10, *) {
// runs on iOS 9 and OS X 10.10
}
你可能好奇这个"*"星号有啥用?它代表了所有其他平台以及所有未来可能出现的平台。你必须它,即使你仅在iOS
下使用。除以之外,你还可以明确watchOS
以及tvOS
的版本(当然只支持Xcode Beta 7.1
之后)。
if #available(OSX 10.0, iOS 9, watchOS 2, tvOS 1, *) {
// runs on OS X 10.0, iOS 9, watchOS 2 and tvOS 1
}
总结: API可用性检查功能保证了代码的安全性。不过,为了在旧项目中使用
iOS 9 SDK
,你不得不做一些必要的迁移工作。