标签:
4.0-1.1 进程
进程为应用程序开辟独立的内存空间;(这块内存空间是独立的,受保护的!进程和进程之间是互不干扰的!)
|
举例 : 比如使用酷狗播放音乐、使用迅雷下载电影,都需要在线程中执行
|
|
概念 : 1个线程中任务的执行是串行的(在线程中的代码是按顺序执行的!同一时间内,只能有一个代码块执行!) |
解析 : 如果要在1个线程中执行多个任务,那么只能一个一个地按顺序执行这些任务
也就是说,在同一时间内,1个线程只能执行1个任务
|
举例 : 比如在1个线程中下载3个文件(分别是文件A、文件B、文件C), 只能一个一个的下载 |
总结 : 因此,也可以认为线程是进程中的1条执行路径 |
问题:为什么开启一条新线程之后就能解决卡住主线程这个问题了呢?
答: 因为线程和线程之间是并发执行(同时执行)!
|
概念 : 1个进程中可以开启多条线程,每条线程可以并行(同时)执行不同的任务 |
优点 : 多线程技术可以提高程序的执行效率 |
举例 : 比如同时开启3条线程分别下载3个文件(分别是文件A、文件B、文件C), 则分别同时下载 |
(1)调度:线程作为调度和分配的基本单位,进程作为拥有资源的基本单位 |
(2)并发性:不仅进程之间可以并发执行,同一个进程的多个线程之间也可并发执行 |
(3)拥有资源:进程是拥有资源的一个独立单位,线程不拥有系统资源,但可以访问隶属于进程的资源. |
(4)系统开销:在创建或撤消进程时,由于系统都要为之分配和回收资源,导致系统的开销明显大于创建或撤消线程时的开销。 |
本质 : 同一时间,CPU只能处理1条线程,只有1条线程在工作(执行)
多线程并发(同时)执行,其实是CPU快速地在多条线程之间调度(切换)
|
原理 : 如果CPU调度线程的时间足够快,就造成了多线程并发执行的假象 |
思考:如果线程非常非常多,会发生什么情况?
答案 :
如果线程非常多,会在多条线程之间来回切换,消耗大量的 CPU 资源
CPU会在N多线程之间调度,CPU会累死,消耗大量的CPU资源
每条线程被调度执行的频次会降低(线程的执行效率降低)
|
iOS 8.0 主线程的默认堆栈大小也是 512K |
(1) 能适当提高程序的执行效率:
|
(2) 能适当提高资源利用率(CPU、内存利用率) |
(1) 开启线程需要占用一定的内存空间(默认情况下,主线程占用1M,子线程占用512KB的栈区空间),如果开启大量的线程,会占用大量的内存空间,降低程序的性能 |
(2) 线程开启越多,CPU 就需要在多条线程之间来回切换,CPU在调度线程上的开销就越大,CPU就越累! |
(3) 开启线程会提高代码的复杂性(会使应用程序增加很多代码!代码变多之后,程序复杂性就会提高!)
程序设计更加复杂:比如线程之间的通信、多线程的数据共享
|
概念 : 一个iOS程序运行后,默认会开启1条线程,称为“主线程”或“UI线程” (程序启动创建的线程) |
作用 :
|
使用注意 :
|
解决方案 :
好处 :
|
标签:
原文地址:http://www.cnblogs.com/shorfng/p/5315593.html