· 程序
Program,是一个静态的概念
· 进程
Process,是一个动态的概念
- 进程是程序的一次动态执行过程,占用特定的地址空间
- 每个进程都是独立的,由3部分组成cpu,data,code
- 缺点:内存的浪费,cpu的负担
· 线程
Thread,是进程中一个”单一的连续控制流程”/执行路径
- 线程又被称为轻量级进程(linghtweight process)
- Threads run at the same time,independently of one another
- 一个进程可能拥有多个并行的(concurrent)线程
- 一个进程中的线程共享相同的内存单元/内存地址空间–>可以访问相同的变量和对象,而且它们从同一堆中分配对象–>通信、数据交换、同步操作
- 由于线程间的通信是在同一地址空间上进行的,所以不需要额外的通信机制,这就使得通信更简便而且信息传递的速度也更快
· 线程和进程的区别
- 根本区别:进程是作为资源分配的单位,线程是调度和执行的单位
- 每个进程都有独立的代码和数据空间(进程上下文),进程间的切换回有较大开销;线程可以看成是轻量级的进程,同一类线程共享代码和数据空间,每个线程都有独立的运行栈和程序技术器(PC),线程切换的开销小。
- 进程在操作系统中能同时运行多个任务(程序);线程在同一应用程序中有个顺序流同时执行
- 进程:系统在运行的时候会为每个进程分配不同的内存区域;线程:除了CPU外,不会为线程分配内存(线程所使用的资源是它所属的进程的资源),线程只能共享资源
- 进程:没有线程的进程是可以被看作单线程的,如果一个进程同时拥有多个线程,则执行过程不是一条线的,而是多条线(线程)共同完成的;线程:线程是进程的一部分,所以线程有的时候被称为是轻权进程或者轻量级进程