进程 线程 协程

本文详细介绍了进程、线程和协程的概念,指出进程是资源分配的基本单位,线程是执行的基本单位,而协程则是用户态的轻量级线程。对比了它们之间的区别,如地址空间、上下文切换开销和安全性。同时,讨论了在不同场景下选择进程或线程的依据,并提到了协程作为异步机制的高效性。
摘要由CSDN通过智能技术生成

进程 线程 协程

进程: 进程是一个具有一定独立功能的程序关于某个数据集合上的一次运行活动,是系统资源分配和独立运行的最小单位;
线程: 线程是进程的一个执行单元,是任务调度和系统执行的最小单位;
协程: 协程是一种用户态的轻量级线程,协程的调度完全由用户控制。

进程与线程的区别

1、根本区别: 进程是操作系统资源分配和独立运行的最小单位;线程是任务调度和系统执行的最小单位。
2、地址空间区别: 每个进程都有独立的地址空间,一个进程崩溃不影响其它进程;一个进程中的多个线程共享该 进程的地址空间,一个线程的非法操作会使整个进程崩溃。
3、上下文切换开销区别: 每个进程有独立的代码和数据空间,进程之间上下文切换开销较大;线程组共享代码和数据空间,线程之间切换的开销较小。

进程和线程的联系

一个进程由共享空间(包括堆、代码区、数据区、进程空间和打开的文件描述符)和一个或多个线程组成,各个线程之间共享进程的内存空间,而一个标准的线程由线程ID、程序计数器PC、寄存器和栈组成。

进程与线程的选择

1、线程的创建或销毁的代价比进程小,需要频繁创建和销毁时应优先选用线程;
2、线程上下文切换的速度比进程快,需要大量计算时优先选用线程;
3、线程在CPU上的使用效率更高,需要多核分布时优先选用线程,需要多机分布时优先选用进程
4、线程的安全性、稳定性没有进程好,需要更稳定安全时优先使用进程。

协程与线程的区别

1、根本区别: 协程是用户态的轻量级线程,不受内核调度;线程是任务调度和系统执行的最小单位,需要内核调度。
2、运行机制区别: 线程和进程是同步机制,而协程是异步机制。
3、上下文切换开销区别: 线程运行状态切换及上下文切换需要内核调度,会消耗系统资源;而协程完全由程序控制,状态切换及上下文切换不需要内核参与。

引用

https://blog.csdn.net/weixin_49199646/article/details/109210547

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值