英文原文:Things I wish I had known before starting iOS development—Part 2
如果你還沒讀這篇文章的第一部分,請先讀完了再來看第二部分。
那些在學習iOS開發前就應該知道的事(part 1):設計師設計出來了一個不錯的引導界面,然而當我看到設計稿的時候,我們的app也沒幾天就要上線了……
在第一部分中,我討論了學習iOS開發的一些基本問題。第二部分將更多地討論一些實際問題,這些問題都是你在開發iOS應用時會遇到的。
Debugging
毋庸置疑,你在開發應用的過程中一定會遇到很多錯誤和異常。比如,你會遇到NSInvalidArgumentException,遇到NSInternalInconsistencyException,還會遇到“0xfaded322”這種錯誤代碼。有時候你可以在Stack Overflow或Quora上找到答案,但大部分時候你得自力更生。
Xcode具有斷點、視圖調試和日志的功能,是debug的不二之選。但畢竟孤掌難鳴,你仍需為它找些得力的幫手。
1.Pony Debugger
square/PonyDebugger:PonyDebugger - 使用Chrome Developer Tools,為你的native iOS應用進行遠程網絡和數據調試。
square開發了這個強大的開源工具。它是一個遠程調試工具,類似於客戶端庫和網關服務器的結合體。它在web浏覽器上使用Chrome Developer Tools,對應用的網絡流量和數據存儲進行調試。作為一個強大的網絡調試器,PonyDebugger允許用戶實時查看應用的網絡請求。它還有另一個酷酷的功能,就是可以遠程調試iOS應用的核心數據棧。
2.Cocoa Lumberjack
CocoaLumberjack:CocoaLumberjack - 快速、簡單,強大、靈活。它就是CocoaLumberjack, 一款好用的Mac和iOS日志框架。
CocoaLumberjack,它快速、簡單,強大、靈活,是一款好用的Mac和iOS日志框架。如果你想找一款強大的日志工具,希望它具有自定義格式化這樣的炫酷功能,那CocoaLumberjack就是你的菜。
3.Reveal App
Reveal:Reveal - iOS應用的runtime視圖調試。
雖然視圖調試已經被引入iOS,但Reveal無疑在調試的細節方面更加強大。它是收費應用,但絕對物有所值。它有一些非常好用的功能,如Auto Layout Inspection。
4.OHHTTPStubs
AliSoftware/OHHTTPStubs:OHHTTPStubs - 輕松stub你的網絡請求。以虛擬網絡數據測試你的應用,可自定義響應時間……
OHHTTPStubs庫可以輕松stub你的網絡請求。它可以幫助你:
使用偽造的網絡數據(stubbed from file)測試你的應用,並模擬慢速網絡以檢查應用在網絡不良情況下的表現。
從設備中獲得偽造的網絡數據,用於寫單元測試。
數據存儲
可能大多數應用都需要將各種任務的數據存儲在本地。數據存儲是一個復雜的話題。它有很多選擇,每個選擇都對應一種情況。但我很喜歡Stack Overflow上的一種法則,用它來選擇數據存儲方式就很不錯。
若數據完全匹配內存且相對非結構化,則使用plist
若數據完全匹配內存且具有樹狀結構,則使用XML
若數據與內存不匹配且具有圖形結構,同時應用不需要額外的查詢能力,則使用Core Data
如果數據與內存不匹配且具有復雜結構,或應用需要關系數據庫提供的強查詢能力,則使用sqlite
如果數據必須保密(例如密碼),則使用keychain。
下面列了一些數據存儲方面的庫,或許對大家有幫助。
FMDB
ccgus/fmdb:fmdb - 圍繞SQLite建立的Cocoa / Objective-C的wrapper
如果你在項目中使用SQLite,此wrapper庫會使你的工作變簡單。
SSFKeychain
soffes/sskeychain:sskeychain - 簡單的Objective-C wrapper,Mac和iOS上的keychain可以使用
要在應用中存儲敏感數據,你必須時刻使用keychain。這個庫可以簡化使用keychain數據存儲的過程。
Magical Record
MagicalRecord - 輕松管理Core Data
Core data非常難於管理。而這個庫可以讓你舒爽地管理Core Data。
網絡
要想讓應用更有趣,你免不了要接入一些API。雖然iOS在對網絡的支持方面表現良好,譬如它擁有NSURLSession、NSURLConnection和NSJSONSerialization,但我還是推薦你使用下面的庫。
AFNetworking
AFNetworking:AFNetworking - 令人拍案叫絕的iOS和OS X網絡框架。
我認為這是有史以來最好的iOS庫之一,它的功能何止炫酷二字。但這些功能中最重要的或許是開發者社區,他們每天都在使用這個庫,並為AFNetworking做出貢獻。一些iPhone、iPad和Mac上最火的應用都是由AFNetworking提供的支持。
Restkit
RestKit/RestKit:RestKit是在iOS和OS X上使用和構建RESTful web資源的框架。
Restkit具有精心設計的API,訪問和構建RESTful資源的過程如沐春風。如果你用core data進行數據存儲、用rest service進行數據讀取,那你的最佳選擇就是它——與Core Data完美集成的Restkit。
Alamofire
Alamofire/Alamofire:Alamofire - Swift下精致的HTTP Networking。
喲喲切克鬧,Swift粉們不要鬧,煎餅果子來一套。下面就是為你們准備的東西了。Alamofire是一個精致的網絡庫,它具有一些Swift專享的強大功能。
你也可以在這裡找到很多其他的庫。
vsouza/awesome-ios
awesome-ios——精選的優質iOS生態系統,包括Objective-C和Swift項目。
依賴管理
我在前面的文章中提到過依賴管理,但重要的問題要說兩遍!在這裡我還要給它細細講一發。在項目中,你主要有三種管理依賴的方式。
CocoaPods
CocoaPods.org:iOS和Mac項目的依賴管理器。
CocoaPods是Swift和Objective-C Cocoa項目的依賴管理器。它擁有將近一萬個庫,可以幫助你輕松擴大項目規模。要想管理Ruby Gems這種依賴,實踐中最有效的方法就是它了。
谷歌開發者做了一個YouTube視頻,解釋了為什麼要在你的項目中使用CocoaPods。小心笑尿。
點此觀看視頻:Route 85: An Introduction to CocoaPods
Github Submodules
你還可以使用git submodules,在項目中以sub repos形式管理依賴。子模塊相對於Cocoapods的優勢在於子模塊也是sub-repos——這不僅是指git和git GUIs逐漸認可並更加支持它們,也意味著你的依賴可以將git repos和廣闊的世界連接起來,而CocoaPods卻不能。
但git submodules也有自己的問題:項目中沒有那些你所依賴的代碼的來源。它只是指向了子模塊庫。而大多數時間你根本不會去管這個庫。
Carthage
Carthage/Carthage:Carthage - 簡單、去中心化的Cocoa依賴管理器。
Carthage旨在為Cocoa應用提供最簡單的框架添加方式。Carthage使用xcodebuild建立framework binaries,把整合工作留給了用戶。CocoaPods的方法更簡單易用,而Carthage的方法更靈活溫和。
不幸的是,Carthage也有一個巨大缺陷——僅支持iOS 8及以上版本。
測試
大多數人一提到應用測試就會呵欠連連。但如果沒有測試的話,說不巧哪天你的應用就突然崩潰了。發布應用時,你一定得先進行深度測試,保證用戶得到最佳體驗。
這裡有很多測試框架,它們可以簡化測試工作。
XCTest
XCTest是一個單元測試框架,包含在Xcode中。它支持把單元測試作為項目編譯過程的一部分。XCTest與XCode高度整合,因此提供了持續整合支持和覆蓋率測試這樣的功能。
KIF
kif-framework/KIF:KIF - Keep It Functional - iOS功能測試框架
KIF是Keep It Functional的縮寫。它由Square開源,是一款iOS一體化測試框架。它利用其可訪問性——即系統讓訪問不能顯示的應用成為可能,輕松實現了iOS應用的自動化。
Kiwi
kiwi-bdd/Kiwi:Kiwi - BDD for iOS
Kiwi是iOS開發的Behavior Driven Development庫。其目標是提供一個安裝和使用都非常簡單的BDD庫。
Quick
Quick/Quick:Quick - Swift (以及Objective-C)的測試框架。
Quick是Swift和Objective-C的一款行為驅動的開發框架。它由RSpec、Specta和Ginkgo開發。與Quick並肩戰斗的是Nimble——一款為測試服務的匹配框架。
我嘗試在本文中講盡量多的技術問題。跳入iOS開發的大坑之後,你就能用得到上我說的這些東西了。關於iOS開發需要說的實在太多,所以在這兒我沒有談到營銷之類的話題。如果你想看的話,那就等我的下一篇文章吧!