进程与线程的区别和联系

  • 定义

进程:具有一定独立功能的程序关于某个数据集合上的一次运行活动,或者说进程就是一段程序的执行过程;

线程:是进程的一个实体,是cpu调度和分派的基本单位,它是比进程更小的能独立运行的基本单位。线程自己不拥有系统资源,只拥有一点在运行中必不可少的资源,但同一个进程的线程共享进程的资源;

  • 区别

调度:进程是拥有资源的基本单位,线程是调度和分派的基本单位;

地址空间:进程拥有独立的地址空间,隔离度好,一个进程的错误一般不会影响其他进程,线程共享进程的地址空间,易共享资源,但是需要程序员管理很多的东西,如果一个线程挂掉,那么整个进程都会挂掉;

资源共享:进程间资源共享比较麻烦,要使用进程间通信,但是同步简单,而同一进程的线程共享资源容易,但同步复杂,需要加锁;

占用内存和CPU:进程占用内存多,切换复杂,CPU利用率低;而线程占用内存少,切换简单,CPU利用率高;

  • 进程间通信

通信方式:管道、信号量、消息队列、共享内存或者socket套接字;

管道:内存中的一种特殊文件,不属于文件系统,有自己的数据结构;

共享内存:利用内存缓冲区直接交换信息,速度快且信息量大;

消息队列:由系统调用函数来实现消息发送和接收之间的同步;

  • 线程同步与异步

同步:一个线程要等到另一个线程执行完之后才开始执行当前的线程;

异步:一个线程执行,它的下一个线程不必等待它执行完就开始执行;

同步使用场景:对于多个线程同时访问一块数据时,必须要使用同步;

异步使用场景:当只有一个线程访问当前数据的时候;

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

BQW_

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值