C语言学习总结#
int main(){
printf("Hello,world!");
return 0;
}
难点和重点##
重要知识点回顾##
数组的使用
Objective-C学习总结#
网络阶段##
应用程序如何连接互联网###
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:iOS7以前的联网方式,主要有两个类方法,一个发送同步请求(阻塞式请求),一个用于发送异步请求(非阻塞式请求)。
- NSURLSession: 通过该对象可以创建三种任务:上传(NSURLSessionUploadTask)、下载(NSURLSessionDownloadTask)和获取数据(NSURLSessionDataTask),任务可以执行(resume)、挂起(suspend)、取消(cancel)。
- NSURLSessionConfiguration:保存所有的联网设置
iOS 9出于安全方面的考虑,不允许使用非安全的HTTP协议联网,需要修改项目的info.plist文件设置允许非安全的HTTP连接。
- 数据解析:
- JSON: NSJSONSerialization可以将服务器响应的二进制形式的数据转换成数据或字典,接下来可以将字典或数组转换成模型对象,快车使用的方式包括:KVC、MJExtension/YYmodel(推荐使用)
- XML:SAX解析(顺序的、事件驱动式的解析,省空间)和DOM(文档对象模型,方便查找[XPath/XQuery])解析。第三方库的解析基本上是DOM解析,比较常用的有:GDataXML,KissXML、RaptureXML。
- 第三方库AFNetWorking的使用:
- AFHTTPSessionManager
- AFURLSessionManager
>注意:AFNetWoring默认只支持JSON格式的响应数据,需要对AFHTTPResponseSerializer进行设置来支持更多的MIME类型。
2.基于套接字(Socket) - 点到点通信
- 和服务器通信
套接字是一套联网的API, 是由一系列的C函数构成的, 有三类套接字:流套接字(基于TCP协议)、数据报套接字(基于UDP)、原始套接字(基于IP协议)。
地图和定位##
- 苹果原生地图、高德地图、百度地图。
- 定位: 如果使用CLLocationManager实现定位服务,通过GPS设备获得的坐标是地球坐标,在国内使用时需要转换成火星坐标。高德地图和百度地图都不直接使用苹果原生的CLLocationManager实现定位,而是对其做了二次封装,提供自己的定位服务的API,通过高德地图、百度地图定位服务获得的坐标已经是修正后的火星坐标或百度坐标,就不需要通过代码进行坐标转换了。iOS 8 以后如果要使用定位服务,必须用户授权,因此需要修改Info.plist文件,设置一直开启或使用时开启定位服务的选项。
- 在地图上添加图形覆盖物和标注
- POI搜索功能
- 全景地图、室内地图
- 计算距离:球面坐标转换成平面坐标(墨卡托坐标)
多线程编程##
- 概念:进程、线程;串行、并行;同步、异步。
- 五中实现方案:
- pthreads
- NSObject拓展:performSelectorInBackground/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:inser、delete、update
- DQL:select
- 投影、筛选、模糊、排序、分组、聚合函数、子查询、连接查询、去重、别名。
-
ER模型:实体和实体间有三种关系,分别是一对一、一对多、多对多。
-
设计表:范式理论,1NF、2NF、3NF、BCNF、4NF。
-
应用程序中需要将数据库放在沙箱的Documents路径下。
-
第三方库FMDB.
- FMDatabase:executeQuery/executeUpdate
- FMResultSet:可以从行中取出指定的列
提示:如果在SQL语句中有占位符,那么替换占位符的必须是对象不能是基本数据类型,否则程序会崩溃。
-
设计专门的持久层
- DAO模式:Data Access Object,封装增删改查(CRUD)的编程接口,以对象为单位来zu'vi
网友评论