一个任务通常就是一个程序,每个运行的程序就是一个进程。当一个程序运行时,内部可能包含了多个顺序执行流,每个顺序执行流就是一个线程。
进程(Process):当一个程序进入内存运行时,即变成一个进程。进程是处于运行过程中的程序,具有一定的独立功能,进程是系统进行资源分配和调度的一个独立单位。
进程包含三个主要特征:
- 1、独立性:进程是系统独立存在的实体,拥有自己独立的资源以及自己私有的地址空间。在没有经过进程本身允许的情况下,一个用户进程不可以直接访问其他进程的地址空间。
- 2、动态性:程序是一个静态的指令集合,进程是一个正在系统中活动的指令集合。进程中加入了时间概念。进程具有自己的生命周期和各种不同的状态,这些概念在程序中是不具备的。
- 3、并发性:多个进程可以在单个处理器上并发执行,多个进程之间不会互相印象。
并发性(concurrency):指在同一时刻只能有一条指令执行,但多个进程指令被快速轮换执行,使得在宏观上具有多个进程同时执行的效果。
并行性(parallel):指在同一时刻,有多条指令在多个处理器上同时执行。
对于一个CPU而言,它在某个时间点只能执行一个程序,也就是说,只能运行一个进程,CPU不断地在这些进行之间轮换执行。
同一个进程可以同时并发处理多个任务。
线程(Thread)也被称作轻量级进程(Lightweight Process),是进程的执行单元,在程序中是独立的、并发的执行流。
当进程被初始化后,主线程就被创建了。对于绝大多数的应用程序来说,通常仅要求有一个主线程,但也可以在该进程内创建多条顺序执行流,这些顺序执行流就是线程,每个线程也是相互独立的。
线程的特点:
- 1、一个进程可以拥有多个线程,一个线程必须有一个父线程
- 2、线程拥有自己的堆栈、程序计数器和局部变量,但不拥有系统资源,而是与父进程的其他线程共享该进程所拥有的全部资源
- 3、线程是独立运行的,它并不知道进程中是否还有其他线程存在
- 4、线程的执行是抢占式的,即当前线程随时可能被挂起,以便其他线程运行
- 5、一个线程可以创建和撤销另一个线程,同一个进程中的多个线程之间可以并发执行
归纳总结:操作系统可以同时执行多个任务,每个任务就是进程;进程可以同时执行多个任务,每个任务就是线程。
多线程编程的优点:
- 1、进程之间不能共享内存,但是线程之间共享内存非常容易
- 2、系统创建进程时需要为该进程重新分配系统资源,但创建线程则代价小得多,因此使用多线程来实现多任务并发比多进程的效率高
- 3、Java语言内置了多线程功能支持,而不是单纯地作为底层操作系统的调度方式,从而简化了Java的多线程编程。
网友评论