基本概念
1 线程的概念
- 程序:Programe,指令集,是一个静态的概念
- 进程:Process,操作系统调度程序,是一个动态的概念
- 进程是程序的一次动态执行过程,占用特定的地址空间
- 每个进程都是独立的,由三部分组成:CPU,Data,Code
- 缺点:内存的浪费,CPU的负担
- 线程:Thread,是进程中的一个“单一连续控制流程”(多条执行路径)
- 线程又被称为轻量级进程(lightweight process)
- 每个线程独立运行
- 一个进程可拥有多个并行的(Concurrent)线程
- 一个进程中的线程共享相同的内存单元/内存地址空间,可以访问相同的变量和对象,而且它们从同一堆中分配对象,实现通信、数据交换和同步操作
- 由于线程间的通信是在同一地址空间上进行的,所以不需要额外的通信机智,这就使得通信更简便而且信息传递的速度更快
2 线程和进程的区别
区别 | 进程 | 线程 |
---|---|---|
根本区别 | 作为资源分配的单位 | CPU调度和执行的单位 |
开销 | 每个进程都有独立的代码和数据空间(进程上下文),进程间的切换会有较大的开销 | 线程可以看成轻量级的进程,同一类线程共享代码和数据空间,每个线程有独立的运行栈和程序计数器(PC),线程切换的开销小 |
所处环境 | 在操作系统中能同时运行多个任务(程序) | 在同一应用程序中有多个顺序流同时执行 |
分配内存 | 系统在运行的时候会为每个进程分配不同的内存区域 | 除了CPU之外,不会为线程分配内存(线程所使用的资源是它所属的进程的资源),线程组只能共享资源 |
包含关系 | 没有线程的进程是可以被看作单线程的,如果一个进程内拥有多个线程,则执行过程不是一条线的,而是多条线(线程)共同完成的 | 线程是进程的一部分,所有线程有的时候被称为是轻权进程或者轻量级进程 |