Swift 2.0 初探

轉眼間,Swift已經一歲多了,這門新鮮、語法時尚、類型安全、執行速度更快的語言已經漸漸的深入廣大開發者的心。我同樣也是非常喜愛這門新的編程語言。 今年6月,一年一度的WWDC大會如期而至,在大會上Apple發佈了Swift 2.0,引入了很多新的特性,以幫助開發者能更快,更簡單的構建應用。我在這裏也說道說道Swift 2.0中值得大家注意的新特性。

 guard語句 

guard語句和if語句有點類似,都是根據其關鍵字之後的表達式的布爾值決定下一步執行什麼。但與if語句不同的是,guard語句只會有一個代碼塊,不像if語句可以if else多個代碼塊。 那麼guard語句的作用到底是什麼呢?顧名思義,就是守護。guard語句判斷其後的表達式布爾值爲false時,纔會執行之後代碼塊裏的代碼,如果爲true,則跳過整個guard語句,我們舉例來看看。 

我們以今年高考爲例,在進入考場時一般都會檢查身份證和准考證,我們寫這樣一個方法:


上述代碼中的第一個guard語句用於檢查身份證,如果檢查到身份證沒帶,也就是表達式爲false時,執行大括號裏的代碼,並返回。第二個guard語句則檢查准考證。

 如果兩證齊全,則執行最後一個打印語句,上面的兩個guard語句大括號內的代碼都不會執行,因爲他們表達式的布爾值都是true。 

這裏值得注意的是,id和examNumber可以在guard語句之外使用,也就是說當guard對其表達式進行驗證後,id和examNumber可在整個方法的作用域中使用,並且是解包之後的。

我們在用一個if else語句寫一個類似的方法


我們可以看到用if else實現的方法顯然不如guard實現的那麼精準。而且id和examNumber的作用域只限在if的第一個大括號內,超出這個作用域編譯就會報錯。

 通過上述兩個小例子不難看出,guard語句正如一個稱職的守衛,層層把關,嚴防一切不允許發生的事,並且讓代碼具有更高的可讀性,非常棒。

異常處理 

在Swift 1.0時代是沒有異常處理和拋出機制的,如果要處理異常,要麼使用if else語句或switch語句判斷處理,要麼使用閉包形式的回調函數處理,再要麼就使用NSError處理。以上這些方法都不能像Java中的try catch異常控制語句那樣行如流水、從容不迫的處理異常,而且也會降低代碼的可讀性。當Swift 2.0到來後,一切都不一樣了。

 在Swift 2.0中Apple提供了使用throws、throw、try、do、catch這五個關鍵字組成的異常控制處理機制。下面我們來舉例看看如何使用,我用使用手機刷朋友圈爲例。

 首先我們需要定義異常枚舉,在Swift 2.0中Apple提供了ErrorType協議需要我們自定義的異常枚舉遵循:



我們定義了導致不能刷微信的錯誤枚舉’wechatError。

然後定義一個檢查是否可以刷微信的方法checkIsWechatOk():



這裏注意,在方法名後有throws關鍵字,意思爲該方法產生的異常向上層拋出。在方法體內使用guard語句對各種狀態進行判斷,然後使用throw關鍵字拋出對應的異常。然後我們定義刷微信的方法:


上述的代碼示例中,首先檢查是否可以刷微信的方法前使用try關鍵字,表示允許該方法拋出異常,然後使用了do catch控制語句捕獲拋出的異常,進而做相關的邏輯處理。 

這套異常處理機制使Swift更加的全面和安全,並且提高了代碼的可讀性,非常棒。 

協議擴展

 在Swift 1.0 時代,協議(Protocol)基本上類似一個接口,定義若干屬性和方法,供類、結構體、枚舉遵循和實現。

在Swift 2.0中,可以對協議進行屬性或者方法的擴展,和擴展類與結構體類似。這讓我們開啓了面向協議編程的篇章。

 Swift中,大多數基礎對象都遵循了CustomStringConvertible協議,比如Array、Dictionary(Swift 1.0中的Printable協議),該協議定義了description方法,用於print方法打印對象。現在我們對該協議擴展一個方法,讓其打印出大寫的內容:


如果在Swfit 1.0時代,要想達到上述示例的效果,那麼我們需要分別對Array、Dictionary進行擴展,所以協議的擴展極大的提高了我們的編程效率,也同樣使代碼更簡潔和易讀。

 打印語句的改變

 在Swift1中,有'println()'和'print()'兩個在控制檯打印語句的方法,前者是換行打印,後者是連行打印。在Swift2中,'println()'已成爲過去,取而代之的是他倆的結合體。如果你想做換行打印,現在需要這樣寫:



available檢查

 作爲iOS開發者,誰都希望使用最新版本iOS的Api進行開發,省事省力。但常常事與願違,因爲我們經常需要適配老版本的iOS,這就會面臨一個問題,一些新特性特性或一些類無法在老版本的iOS中使用,所以在編碼過程中經常會對iOS的版本做以判斷,就像這樣:


以上這只是一種方式,在Swift 2.0之前也沒有一個標準的模式或機制幫助開發者判斷iOS版本,而且容易出現疏漏。在Swift 2.0到來後,我們有了標準的方式來做這個工作:



這個特性讓我們太幸福。 

do-while語句重命名 

經典的do-while語句改名了,改爲了repeat-while:

個人感覺更加直觀了。 

defer關鍵字 

在一些語言中,有try/finally這樣的控制語句,比如Java。這種語句可以讓我們在finally代碼塊中執行必須要執行的代碼,不管之前怎樣的興風作浪。在Swift 2.0中,Apple提供了defer關鍵字,讓我們可以實現同樣的效果。


上述示例可以看到,在打印出“CheckPoint 2”之後並沒有打印出“Clean up here”,而是“CheckPoint 3”,這就是defer的作用,它對進行了print("Clean up here")延遲。我們再來看一個I/O的示例:


上述示例是一個I/O操作的僞代碼,如果獲取到的ioStatus正常,那麼該方法沒有問題,如果ioStatus取到的是error,那麼會被guard語句抓到執行return操作,這樣的話closeFile(file)就永遠都不會執行了,一個嚴重的Bug就這樣產生了。下面我們看看如何用defer來解決這個問題:

我們將closeFile(file)放在defer代碼塊裏,這樣即使ioStatus爲error,在執行return前會先執行defer裏的代碼,這樣就保證了不管發生什麼,最後都會將文件關閉。 defer又一個保證我們代碼健壯性的特性,我非常喜歡。 Swift 2.0中的新特性當然不止以上這些,但窺一斑可見全貌!


發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章