进程和线程的区别与联系

1. 从概念出发

进程是程序运行的活动实体,操作系统会为一个进程分配TCP(进程控制块),虚拟地址空间,页表等一些资源。
线程是轻量级进程,是程序运行的某一片段,是进程内部的一部分,操作系统只会给它分配一点够程序运行的资源,所有线程共享进程的地址空间。

2. 资源分配与调度

所以进程是资源分配的最小单位,线程是调度的最小单位。

3.资源占有角度

操作系统会为一个进程分配一堆资源,所有的进程之间是独立的,是互不影响的。
而所有线程共享进程的虚拟地址空间,只拥有一小部分资源,比如自己的线程ID,私有栈空间,自己的上下文数据等。
就是因为线程共享资源,所以一个线程的异常退出会影响整个进程异常退出,并且要注意线程间的同步与互斥问题。

4. 调度与切换

(1)因为进程携带一大堆的资源,所以创建和撤销一个进程的代价要比创建和撤销一个线程大的多。
(2)因为进程携带一堆资源,所以进行进程之间的切换或调度时,操作系统要做的工作比线程之间的切换或调度多得多。

5. 通信

对于进程间通信,最主要就是让两个不相干的进程之间看到同一份资源,但是对于两个进程而言,通信要比线程难得多,两个线程之间的通信是很容易进行的。

6. 并行

不仅进程间可以并发执行,线程之间也可以并发执行。但是由于进程的创建、撤消和切换,系统的开销比较大,所以创建的进程数目不能太多,而线程的划分尺度比进程小,所以并发性比进程高,效率和吞吐量都比较高。
线程在执行程序的过程中,每个线程有自己的程序入口,函数栈帧,函数出口等。

7. 创建线程和进程

在Linux下,创建一个子进程可以用fork和vfork函数,在子进程运行完毕后,必须由父进程对子进程进行回收(wait,waitpid,发送信号),否则子进程会成为僵尸进程,会造成资源泄漏。
创建一个新线程可以用pthread_create函数,在新线程运行完成后,也必须回收,否则会造成资源泄漏。如果不想回收,则可以利用detach函数对线程进行分离。

【补充:线程的优缺点】
优点
(1)线程是轻量级进程,携带的资源很少,创建一个线程的代价较小。
(2)与进程间的切换相比,线程间的切换操作系统要做的工作较小。
(3)线程占用的资源很少。
(4)线程可以充分利用多处理器数量,并发性高。
(5)在等待慢速IO的同时,可以做计算型任务。
(6)对于计算密集型任务和IO密集型任务,线程的效率都比较高。
缺点
(1)性能缺失
假设在计算密集型任务中,创建了很多的线程,但是线程的数量比处理器的数量多,那么会造成多余线程在等待,造成性能缺失。
(2)安全性降低
容易引发线程安全等问题,需要使用多线程的同步与互斥机制。
(3)编程难度提高
编写与调试一个多线程程序比单线程困难的多。

  • 0
    点赞
  • 7
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
进程是操作系统进行资源分配的基本单位,而线程进程内的一个执行单元,也是进程内的可调度实体。一个进程可以包含多个线程,而线程共享了进程的某些资源。进程线程之间存在以下区别: 1. 本质区别进程是操作系统进行资源分配的基本单位,而线程是独立调度和分派的基本单位。 2. 包含关系:一个进程内可以有多个线程线程进程的一部分,因此线程也被称为轻量级进程或轻权进程。 3. 资源开销:每个进程都有独立的代码和数据空间,程序之间的切换会有较大的开销;而线程可以看作轻量级的进程,同一类线程共享代码和数据空间,线程之间切换的开销小。 4. 创建和销毁:创建一个进程需要遍历内存资源找到合适的内存再分配给它,销毁进程也需要遍历内存资源。而创建和销毁一个线程相对不那么麻烦。 5. 内存分配:同一个进程线程共享本进程的地址空间和资源,而进程之间的地址空间和资源是相互独立的。 6. 影响关系:一个进程崩溃后,在保护模式下不会对其他进程产生影响;但一个线程崩溃可能会导致包含该线程的整个进程直接死掉。 7. 操纵者不同:进程的操纵者一般是操作系统,线程的操纵者一般是编程人员。 8. 执行过程:每个独立的进程有程序运行的入口、顺序执行序列和程序出口,而线程不能独立执行,必须依存在应用程序中,由应用程序提供多个线程执行控制。
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值