进程:是具有一定独立功能的程序关于某个数据集合上的一次运行活动,他是系统进行资源分配和调度的一个独立单位。
例:
用户运行自己的程序,系统就创建一个进程,并为它分配资源,包括各种内存,I/O设备等。
然后改进程就被放入到进程的就绪队列,一旦该进程获得CPU就会运行起来。
线程:是进程的一个实体,是CPU调度和分配的基本单位,线程自己基本上不拥有系统资源,只拥有一点在运行中必不可少的资源,(如程序计数器,一组寄存器和栈),但是它可以与同属于一个进程的线程共享进程所拥有的全部资源。
在没有线程的操作系统中,进程既是资源分配的基本单位又是调度的基本单位,它是系统中并发执行的单元。
而在实现了线程的操作系统中,进程是资源分配的基本单位,但线程是调度的基本单位和系统并发执行的单元。
引入线程主要有以下四个方面的优点:
(1) 易于调度
(2) 提高并发性
(3) 开销小,创建线程比创建进程要快,所需的开销也更少。
(4) 有利于发挥多处理器的功能。通过创建多个线程,每个线程在一个处理器上运行,从而实现程序的并行,使每个处理器都得到充分运行。
需要注意的是,,尽管线程跟进程很相似,但两者也存在着很大的不同,区别如下:
(1)一个线程必定属于也只能属于一个进程;而一个进程可以拥有多个线程并且至少拥有一个线程。
(2)属于一个进程的所有线程共享该进程的所有资源,包括打开的文件,创建的Socket等
不同的进程互相独立。
(3)线程又被称为轻量级进程。进程有进程控制块,线程有线程控制块。但线程控制块比进程控制块小得多。线程间切换代价少,进程间切换代价大。
(4)进程是程序的一次执行,线程可以理解为程序中一段程序片段的执行,
(5)每个进程都有独立的内存空间,而线程共享其所属的内存空间。
(6)一个线程可以创建和撤销另一个线程,同一个进程中的多个线程之间可以并发执行。