网络阶段#
应用程序如何连接互联网##
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请求
-NSURLRespanse:HTTP响应(服务器给应用的响应)
-iOS7以前的联网:NSURLConnection 主要有两个类方法,一个用于发送同步请求(阻塞式请求),一个用于发送异步请求(非阻塞式请求)。
-NSURLSession:通过该对象可以创建三种任务:上传(NSURLSessionUploadTask),下载(NSURLSessionDownloadTask)和获取数据(NSURLSessionConfiguration),而且可以控制三种任务执行(resume),挂起(suspend),取消(cancel)。
-NSURLSessionConfiguration:保存所有的联网设置
iOS 9出于安全方面的考虑,不允许使用非安全的HTTP协议联网,需要修改项目的info.plisit文件允许非安全的HTTP连接。
-JSON:NSJSONSerialization可以将服务器响应的二进制形式的JSON数据转化成数组或字典,接下来将数组或字典转化成模型对象,可以使用的方式包括:KVC,JSONKit,JSONModel,MJExtension,YYModel(推荐只用)。
-XML:SAX解析(顺序的,事件驱动式的解析,省空间)和DOM(文档对象模型,方便查找【XPath/XQuery】)解析。第三方库的解析基本上是DOM解析,比较常用的:GDataXML,KissXML,RaptureXML。
-第三方库AFNetworking
-AFURLSessionManager
-AFHTTPSessionManager
注意: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搜索功能
-街景地图,室内地图
-计算距离:球面坐标转换成平面坐标(墨卡托坐标)
多线程编程##
-概念:进程,线程,串行,并行,同步,异步。
-五种实现方案:
-pthreads
-NSObject扩展:performSelectorlnBackground/performSelectorOnMainThread
-NSThread
-NSOperationQueue/NSOperation(NSInvocationOperation/NSBlockOperation)
-GCD的使用场景:
dispatch_async(dispatch_get_global_queue(0,0),^{
//执行耗时操作
dispatch_async(dispatch_get_min_queue(),^{
//刷新界面
});
});
嵌入式数据库##
-实现持久化操作,有效的管理数据。
-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语句中有占位符,那么替换占位符的必须是对象不能是基本数据类型,否则程序会崩溃。