一、什么是进程与线程
进程(Process)是计算机中的程序关于某数据集合上的一次运行活动,是系统进行资源分配和调度的基本单位,是操作系统结构的基础。程序是指令、数据及其组织形式的描述,进程是程序的实体。
简单来说就是我们运行一个程序时系统就会创建一个进程,并且对这个进程进行资源的分配。
我们打开电脑的任务管理器,可以清楚的看到当前电脑上有那些进程具体分配了那些资源
线程(thread)是操作系统能够进行运算调度的最小单位。它被包含在进程之中,是进程中的实际运作单位。一条线程指的是进程中一个单一顺序的控制流,一个进程中可以并发多个线程,每条线程并行执行不同的任务。
二、进程和线程的关系
通过上面进程和线程的定义,我们不难看出 1.进程是系统进行资源分配和调度的基本单位,线程是进行运算调度的最小单位,线程是再进程里面的,它可以是多个,可以并行执行不同的任务 2.进程在被创建的时候所分配的资源(代码和常量、全局变量和静态变量、堆存储等)是被所有线程共享的,但是每个线程拥有自己的栈段,栈段又叫运行时段,用来存放所有局部变量和临时变量。
简单来说二者关系,进程就是一个再创建、撤销和切换中时空开销较大的资源拥有者,所以导致系统并发的成本较高,限制了并发,因此人们提出了线程,使其作为运算调度分派的最小单位解决并发问题。
三、进程和线程的区别
1.调度
在同一进程中,线程的切换不会引起进程的切换,在 由一个进程中的线程切换到另一个进程中的线程时,将会引起进程的切换。
2.并发性
在引入线程的操作系统中,不仅进程之间可以并发执行,而且在一个进程中的多个线程之间,亦可并发执行
3.拥有资源
进程是拥有资源的一个独立单位,它可以拥有自己的资源,而线程自己不拥有系统资源(也有一点必 不可少的资源),只是可以使用进程的资源
4.系统开销
进程开销大,线程开销小
|