1 多线程概述
平时我们一般编写的程序都是单线程程序,只有一条顺序执行流——程序从main()方法开始执行,一步一步向下执行直到main方法结束。这种情况,如果程序执行某行代码时遇到阻塞,那么程序将会停滞在该处。
多线程的程序区别于单线程,即可以包含多个顺序执行流,多个顺序流之间互不干扰。打个比方:单线程的程序如同只有一个服务员的餐厅,只有做完一件事他才可以做下一件事;而多线程的程序就是有很多个服务员的餐厅,他们可以同时做很多件事情。
2 线程与进程
2.1 进程
几乎所有的操作系统都支持同时运行多个任务,一个任务通常就是一个程序,每个运行中的程序就是一个进程(Process)。当一个程序运行时,内不可能包含了多个顺序执行流,每个顺序执行流就是一个线程。
进程具有一定的独立功能,进程是系统进行资源分配和调度的一个独立单位。进程的特征:
- 独立性:进程是系统中独立的实体,拥有自己独立的资源,拥有自己私有的地址空间。
- 动态性:进程是一个正在执行程序的实例,拥有自己的生命周期和各种状态。
- 并发性:多个进程可以在单个处理器上并发执行,多个进程之间不会互相影响。
现代操作系统都支持多进程的并发,但在具体的实现细节上可能因为硬件和操作系统的不同而采用不同的策略。比如共用式的多任务操作策略、抢占式多任务操作策略。
并发与并行
并发