2024年Go最新进程 线程 协程 各自的概念以及三者的对比分析_lwp是协程吗,瞬间高大上了

img
img

网上学习资料一大堆,但如果学到的知识不成体系,遇到问题时只是浅尝辄止,不再深入研究,那么很难做到真正的技术提升。

需要这份系统化的资料的朋友,可以添加戳这里获取

一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!

进程状态图

2 线程

概念

线程,有时被称为轻量级进程(LightWeight Process,LWP),是操作系统调度(CPU调度)执行的最小单位。

示意图

线程状态图

3 进程和线程的区别和联系

3.1 区别

  • 调度:进程作为拥有资源的基本单位,线程作为调度和分配的基本单位
  • 并发性:不仅进程之间可以并发执行,同一个进程的多个线程也可以并发执行
  • 拥有资源:
    • 进程是拥有资源的基本单位,线程不直接拥有资源。
    • 线程可以访问隶属于进程的资源
    • 进程所维护的是程序所包含的资源(静态资源),比如:地址空间、打开的文件句柄、文件系统状态,信号处理handler
    • 线程所维护的是程序运行相关的资源(动态资源),如:运行栈、调度相关的控制信息、待处理的信号集…
  • 系统开销:
    • 进程的系统开销更大:在创建或者销毁进程时,由于系统需要位置分配和回收资源,导致系统的开销明显大于创建或者销毁线程时的开销。
    • 进程更稳定安全:
      • 进程有独立的内存空间,一个进程崩溃后,在保护模式下对其他进程不会有影响
      • 而线程只是一个进程中的不同的执行路径
    • 线程有自己的堆栈和局部变量,但是线程没有独立的地址空间,一个进程死掉等于该进程下所有的线程死掉。
      • 所以多进程的程序要比多线程的的程序稳健,但在多进程切换时,耗费资源大,性能较差。

3.2 联系

  • 一个线程只能属于一个进程,一个进程可以有多个线程,至少有一个线程
  • 资源分配给进程,同一进程的所有线程共享改进程的所有资源
  • 处理机(中央处理器+主存储器+输入输出设备)分配资源给进程,即真正运行在处理机上的是进程
  • 线程在执行过程中,需要协作同步。不同进程的线程间要利用消息通信的方式实现同步

4 举例说明进程和线程的区别

示例图

这幅图是一个双向多通道的道路图,加入我们把整个道路看做一个“进程”的话,那种图中由白色虚线分割开的车道就是进程中的各个“线程”了

  • 这些车道(线程)共享了道路(进程)的土地资源(系统资源)
  • 这些车道(线程)必须依赖于道路(进程),否则车道将没有意义(线程不能脱离于进程而存在)
  • 这些车道(线程)之间可以并发运行(各个车道你走你的,我走我的),也可以同步运行(遇到红灯的情况,需要等待特点条件后再执行)
  • 这些车道(线程)的运行和交通灯(代码逻辑)息息相关,如果交通灯出现问题(代码逻辑问题,比如死锁,多个线程同时竞争同一资源),会造成交通混乱
  • 这些车道(线程)谁先运行起来是未知的,只有当信号灯变化(分配CPU时间的时候)那刻才知道

5 进程/线程之间的亲缘性

概念

亲缘性的意思是进程/线程只在某个CPU上运行(多核系统)

好处

使用CPU亲缘性的好处:防止进程/线程在CPU的多核间频繁切换,从而避免因切换带来的CPU的L1/L2 cache失效,cache失效会降低程序的性能。

6 协程

示意图

示意图

概念

  • 协程,是一个比线程改轻量级的存在,协程完全由程序控制(也就是在用户态执行)
    • 协程不被操作系统内核所管理
    • 协程能极大的提升性能,不会像线程切换那样消耗资源
  • 子程序,又称为“函数”。
    • 在所有语言中都是层级调用的,A调用B,B调用C,C执行完毕返回,B执行完毕返回,最终A执行完毕
    • 由此可见,子程序调用是通过栈实现的,一个线程就是执行一个子程序。

线程(执行一个函数)和协程的区别和联系

  • 函数总是一个入口,一个返回,调用顺序是明确的(一个线程就是执行一个函数)
  • 而协程的调用和函数不同,协程在函数内部是可以中断的,可以转而执行别的函数,在适当的时候再返回来接着执行。
def A(){
    print 1
    print 2
    print 3
}



![img](https://img-blog.csdnimg.cn/img_convert/644bddbe3fe4ff34d836b5546b5a959e.png)
![img](https://img-blog.csdnimg.cn/img_convert/e0775ac77cdc9a249443188e5f07990e.png)
![img](https://img-blog.csdnimg.cn/img_convert/58d52c89913d13d37d4dcee014929230.png)

**既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,涵盖了95%以上Go语言开发知识点,真正体系化!**

**由于文件比较多,这里只是将部分目录截图出来,全套包含大厂面经、学习笔记、源码讲义、实战项目、大纲路线、讲解视频,并且后续会持续更新**

**[如果你需要这些资料,可以戳这里获取](https://bbs.csdn.net/topics/618658159)**

阶课程,涵盖了95%以上Go语言开发知识点,真正体系化!**

**由于文件比较多,这里只是将部分目录截图出来,全套包含大厂面经、学习笔记、源码讲义、实战项目、大纲路线、讲解视频,并且后续会持续更新**

**[如果你需要这些资料,可以戳这里获取](https://bbs.csdn.net/topics/618658159)**

  • 5
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值