网络阶段#
应用程序如何连接互联网##
1.基于HTTP协议
- HTTP:超文本传输协议(Hyper-Text Markup Language),基于字符的无状态协议,有请求和响应两种格式,HTTP是基于TCP的,这就意味着它是一个可靠的通信协议。
TCP/IP模型是Internet的基石,是一个分层模型,从下往上依次是物理链路层、网络层(IP,寻址和路由)、传输层(TCP/UDP,前者是可靠通信协议,后者是不可靠通信协议)和应用层(HTTP/FTP/POP3/SMTP/Telent)。
- 相关API:
- NSURL:统一资源定位符,协议://域名或者IP地址:端口号/路径/资源
- NSURLRequest / NSMutableURLRequest:HTTP请求(应用对服务器的请求)
- NSURLResponse:HTTP响应(服务器给应用的响应)
- NSURLConnection:iOS 7以前的联网方式,主要有两个方法,一个用于发送同步请求(阻塞式请求),一个用于发送异步请求(非阻塞式请求)。
- NSURLSession:通过该对象可以创建三种任务:上传(NSURLSessionUploadTask)、下载(NSURLSessionDownloadTask )和获取数据(NSURLSessionDataTask),任务可以执行(resume)、挂起(suspend)和取消(cancel)。
- NSURLSessionConfiguration:保存所有的联网设置
iOS 9 出于安全方面的考虑,不允许使用非安全的HTTP协议联网,需要修改项目的 Info.plist文件设置允许非安全HTTP连接。
数据解析
JSON:NSJSONSeriallzation可以将服务器响应的二进制数据转换成数组或字典,接下来可以将字典或数组转换成模型对象。可以使用的方式包括:KVC、JSONKit、JSONModel、MJExtension、YYModel(推荐使用)
XML:SAX解析(事件驱动式顺序解析,省空间)DOM解析(文档对象模型,方便查找[XPath/XQurey],省时间)。第三方库的提供的解析基本上是DOM解析,比较常用的有:GDataXML、KissXML、RaptureXML。
-
第三方库AFNetworking的使用:
- AFHTTPSessionManager
- AFURLSessionManager
注意:AFNetworking默认只支持JSON格式的响应数据,需要设置AFHTTPResponseSerializer进行设置来支持更多MIME类型
2.基于套接字(Socket)
- 点到点通信
- 和服务器通信
套接字是一套联网的API,是由一系列的C函数构成的,有三类套接字:流套接字(基于TCP协议)、数据报套接字(基于UDP)、原始套接字(基于IP协议)。
地图和定位##
- 苹果原生地图(使用苹果数据)、高德地图、百度地图。
- 定位:如果使用CLLocationManager实现定位服务,通过GPS获得的坐标是地球坐标,在国内使用时需要转换成火星坐标。高德地图和百度地图都不是直接使用苹果原生的CLLocationManager实现定位,而是做了二次封装,提供了自己的定位服务API,通过高德地图、百度地图定位服务获得的坐标已经是修正后的火星坐标或百度坐标,就不需要通过代码进行坐标转换。iOS 8开始如果要使用定位服务必须用户授权,因此需要修改Info.plist文件,设置一直开启或使用时开启定位服务选项。
- 在地图上添加图形覆盖物和标注
- POI搜索功能
- 街景地图、室内地图
- 计算距离:球面坐标转换成平面坐标(魔卡托坐标)
多线程编程##
- 概念:进程、线程;串行、并行;同步、异步。
- 五种实现方案:
- pthreads
- NSObject扩展:performSelectorInBackground / performSelectorOnMainThread
- NSThread
- NSOperationQuene / NSOperation (NSInvocationOperation / NSBlockOperation)
- GCD的使用场景:
dispatch_async(dispatch_get_global_quene(0,0),^{ //执行耗时操作 dispatch_async(dispatch_get_main_quene(),^{ //刷新界面 }); });
嵌入式数据库##
- 实现持久化操作,有效的管理数据
- SQLite,关系型数据库,用二维表组织数据,支持SQL
- DDL:create、drop、alter
- DML:insert、delete、update
- DQL:select
- 投影、别名、筛选、模糊、排序、去重、聚合函数、子查询、连接查询
- ER图:实体和实体之间有三种关系,分别是一对一,一对多,多对多
- 设计表:范式理论,1NF、2NF、3NF、BCNF、4NF
- 应用程序中需要将数据库放在沙箱的Documents路径下
- 第三方库FMDB
- FMDatabase:executeQuery/executeUpdate
- FMResultSet:可以从行中取出指定的列
提示:如果在SQL语句中有占位符,那么替换占位符的必须是对象不能是基本数据类型,否则要崩
- 设计专门持久层
- DAO模式:Data Access Object,封装增删改查(CRUD)的编程接口,以对象为单位来组织数据