进程与线程的区别
进程与线程的区别有开销不同、所处环境不同、内存分配不同等。
每个进程都有独立的代码和数据空间(程序上下文),程序之间的切换会有较大的开销。线程可以看做轻量级的进程,每个线程都有自己独立的运行栈和程序计数器(PC),线程之间切换的开销小。
在操作系统中能同时运行多个进程(程序),而在同一个进程(程序)中有多个线程同时执行(通过CPU调度,在每个时间片中只有一个线程执行)。
系统在运行的时候会为每个进程分配不同的内存空间,对线程而言,除了CPU外系统不会为线程分配内存(线程所使用的资源来自其所属进程的资源),线程组之间只能共享资源。
进程与线程的关系
进程(process)和线程(thread)是操作系统的基本概念,但是它们比较抽象,不容易掌握。计算机的核心是CPU,它承担了所有的计算任务。它就像一座工厂,时刻在运行。假定工厂的电力有限,一次只能供给一个车间使用。也就是说,一个车间开工的时候,其他车间都必须停工。背后的含义就是,单个CPU一次只能运行一个任务。
进程就好比工厂的车间,它代表CPU所能处理的单个任务。任一时刻,CPU总是运行一个进程,其他进程处于非运行状态。一个车间里,可以有很多工人。他们协同完成一个任务,线程就好比车间里的工人。一个进程可以包括多个线程,车间的空间是工人们共享的,比如许多房间是每个工人都可以进出的。这象征一个进程的内存空间是共享的,每个线程都可以使用这些共享内存。