攻略

谈一谈进程、线程与协程

  • 来源:博客园
  • 时间:2023-06-28 05:15:27


(相关资料图)

进程、线程、协程概念什么是进程

进程是程序的一次执行过程,是系统运行程序的基本单位,因此进程是动态的。系统运行一个程序即是一个进程从创建,运行到消亡的过程。在 Java 中,当启动 main 方法时其实就是启动了一个 JVM 的进程,而 main 方法所在的线程就是这个进程中的一个线程,称为主线程。

进程是资源分配的基本单位。每一个进程都有它自己的内存空间和系统资源。

进程具有的特征:

动态性:进程是程序的一次执行过程,是临时的,有生命期的,是动态产生和消亡的;并发性:任何进程都可以同其他进程一起并发执行;独立性:进程是系统进行资源分配的基本单位;结构性:进程由指令集、数据和进程控制块三部分组成。什么是线程

线程是操作系统提供的抽象概念,是程序执行中一个单一的顺序控制流程,是程序执行流的最小单元,是处理器调度和分派的基本单位。一个进程可以有一个或多个线程,同一进程中的多个线程将共享该进程中的全部系统资源,如虚拟地址空间,文件描述符和信号处理等等。但同一进程中的多个线程有各自的调用栈和线程本地存储

什么是协程

协程(Coroutine,又称微线程),是一种基于线程之上,但又比线程更加轻量级的存在,这种由程序员自己写程序来管理的轻量级线程叫做『用户空间线程』,具有对内核来说不可见的特性。

协程是用户级线程,具有自己的寄存器上下文和调度器,在单个线程中实现多个协程间的切换。

因为是自主开辟的异步任务,所以很多人也更喜欢叫它们纤程(Fiber),或者绿色线程(GreenThread)。正如一个进程可以拥有多个线程一样,一个线程也可以拥有多个协程。

进程和线程的区别本质区别: 进程是操作系统资源分配的基本单位,而线程是处理器任务调度和执行的基本单位。包含关系: 一个进程至少有一个线程,线程是进程的一部分,所以线程也被称为轻权进程或者轻量级进程。资源开销: 每个进程都有独立的地址空间,进程之间的切换会有较大的开销;线程可以看做轻量级的进程,同一个进程内的线程共享进程的地址空间,每个线程都有自己独立的运行栈和程序计数器,线程之间切换的开销小。影响关系: 一个进程崩溃后,在保护模式下其他进程不会被影响,但是一个线程崩溃可能导致整个进程被操作系统杀掉,所以多进程要比多线程健壮。线程 VS 协程

线程是协作式多任务的轻量级线程,本质上描述了同协程一样的概念。其区别,如果一定要说有的话,是协程是语言层级的构造,可看作一种形式的控制流,而线程是系统层级的构造,可看作恰巧没有并行运行的线程。这两个概念谁有优先权是争议性的:线程可看作为协程的一种实现,也可看作实现协程的基底。

总的来说,协程提高了程序的执行的效率。如果我们的系统是多核的,我们可以利用多核加上协程最大程度的发挥系统性能。

总结

不同的场景下我们该如何选取合适的方案,如下:

IO密集型:多线程(协程维护成本较高,而且在读写文件方面效率没有显著提升)CPU密集型:多进程IO密集和CPU密集:多进程+协程

关键词:

推荐内容

Copyright @  2015-2022 北冰洋教育装备网版权所有  

备案号:沪ICP备2020036824号-3

  

联系邮箱:562 66 29@qq.com