IOS開發總結

網絡階段#

應用程序如何連接互聯網##

1.基于HTTP協議

  • HTTP:超文本傳輸協議(Hyper-Text Markup Language),基于字符的無狀態協議,有請求和響應兩種格式,HTTP是基于TCP的意味著是一個可靠的通信協議。

TCP/IP模型是Internet的基石,是一個分層模型,從下往上依次是物理鏈路層、網絡層(IP,尋址和路由)、傳輸層(TCP/UDP,前者是可靠通信協議,后者是不可靠通信協議)和應用層(HTTP/FTP/POP3/SMTP/Telent)。

  • 相關API:
  • NSURL:統一資源定位符,協議://域名或者IP地址:端口號/路徑/資源
  • NSURLRequest/NSURLMutableRequest:HTTP請求
  • NSURLResponse:HTTP響應(服務器給應用的響應)
  • NSURLConnection:IOS 7以前的聯網方式,主要有兩個類方法,一個是同步請求,一個是異步請求。
  • NSURLSession:通過該對象可以創建三種任務(上傳(NSURLSessionUploadTask)、下載(NSURLSessionDownloadTask)、獲取數據(NSURLSessionDataTask)),而且可以三種任務執行(resume)、掛起(suspend)、取消(cancel)。
  • NSURLSessionConfiguration:保存所有的聯網設置。

IOS 9出于安全方面考慮,不允許使用非安全的HTTP協議聯網,需要修改項目的Info.plist文件設置允許非安全的HTTP鏈接。

  • 數據解析:
  • JSON:SNJSONSerialization可以將服務器響應的二進制形式JSON數據轉換成數組或者字典,接下來將字典或數組轉換成模型對象,可以使用方式:KVC、YYModel(推薦使用)、MJExtension、JSONKit、JSONModel。
  • XML:SAX解析(順序的、事件驅動式的解析,省空間)和DOM解析(文檔對象模型,方便查找[XPath/XQuery])。第三方庫解析基本上是DOM解析,常用:GDataXML,KissXML,RaptureXML。
  • 第三庫AFNetworking的使用:
  • AFURLSessionManager
  • AFTHHPSessionManager
    注意:AFNetworking默認只支持JSON格式的響應數據,需要對AFHTTPResponseSerializer進行設置來支持更多的MIME類型。
    2.基于套接字(Socket)
  • 點到點通信
  • 和服務器通信

套接字是一套聯網的API,是由一系列的C函數構成的,有三類套接字:流套接字(基于TCP協議)、數據報套接字(基于UDP協議)、原始套接字(基于IP協議)。詳細內容參考《IOS and OS X Network Programming Cookbook》一書。

地圖和定位##

  • 蘋果原生地圖(國內使用高德數據)、高德地圖(火星坐標)、百度地圖(熊掌坐標)。
  • 定位:如果使用CLLocationManager實現定位服務,獲得GPS設備獲得的是地球坐標,在國內使用時需要轉換成火星坐標。高德地圖和百度地圖對CLLocationManager做了封裝,提供了自己的定位服務的API,通過高德地圖、百度地圖定位服務獲得的坐標是修改后的火星做百度坐標,不需要通過代碼來轉換。IOS 8開始如果使用定位服務,必須用戶授權,因此需要修改Info.plist文件,設置一直開啟或使用時開啟定位服務的選項。
  • 地圖上添加圖形覆蓋物和標注
  • POI搜索功能
  • 街景地圖、室內地圖
  • 計算距離:球面坐標轉換成平面坐標(墨卡托坐標)

多線程編程##

  • 概念:進程、線程;串行、并行;同步、異步。
  • 5種實現方法:
  • pthreads
  • NSObject擴展:perfromSelectorInBackground/
    performSelectorOnMainThread
  • NSThread
  • NSOperationQueue /NSOperation(NSInvocationOperation/NSBlockOperation)
  • GCD的使用場景:
Objective -C
dispatch_async(dispatch_get_global_queue(0,0),^{
//執行耗時操作
dispatch_async(dispatch_get_main_queue(),^{
//刷新界面
});
});

嵌入式數據庫##

  • 實現持久化操作,有效的管理數據。
  • SQLite,關系型數據庫,用二維表組織數據支持SQL。
  • DDL:create、drop、alter
  • DML:insert、delete、update
  • DQL:select
  • 投影、別名、篩選、去重、排序、分組、聚合函數、子查詢、連接查詢
  • ER圖:實體和實體之間有三種關系,分別是一對一,一對多,多對多。
  • 設計表:范式理論,1NF、2NF、3NF、BCNF、4NF。
  • 應用程序中需要將數據庫放在沙箱Documents路徑下
  • 第三方庫FMDB。
  • FMDatabase:executeQuery/executeUpdata
  • FMResultSet:可從行中取出指定的列

提示:如果在SQL語句中有占位符,那么替換占位符的必須是對象不能是基本數據類型,否則程序會崩潰。

  • DAO模式: Data Access Object,封裝增刪改查(CRUD)的編程接口
最后編輯于
?著作權歸作者所有,轉載或內容合作請聯系作者
平臺聲明:文章內容(如有圖片或視頻亦包括在內)由作者上傳并發布,文章內容僅代表作者本人觀點,簡書系信息發布平臺,僅提供信息存儲服務。

推薦閱讀更多精彩內容