汝州市住房和城乡规划建设局网站,淄博企业网站建设价格,苏州姑苏区网站建设,网络系统建设与运维职业技能等级证书文章目录1. 概述2. 进程3. 线程4. 协程5. 进程与线程区别1. 概述
进程和线程这两个名词天天听#xff0c;但是对于它们的含义和关系其实还有点懵的#xff0c;其实除了进程和线程#xff0c;还存在一个协程#xff0c;它们的关系如下#xff1a; 首先#xff0c;我们需要…
文章目录1. 概述2. 进程3. 线程4. 协程5. 进程与线程区别1. 概述
进程和线程这两个名词天天听但是对于它们的含义和关系其实还有点懵的其实除了进程和线程还存在一个协程它们的关系如下 首先我们需要明白一个笼统的定义并不严谨进程 线程 协程。
它们的基本概念如下
进程 是并发执行的程序在执行过程中分配和管理资源的基本单位是一个动态概念竞争计算机系统资源的基本单位。线程 是进程的一个执行单元是进程内科调度实体。比进程更小的独立运行的基本单位。线程也被称为轻量级进程。协程 是一种比线程更加轻量级的存在。一个线程也可以拥有多个协程。其执行过程更类似于子例程或者说不带返回值的函数调用。 2. 进程
打开任务管理器可以看见当前系统正在运行的所有进程这些进程都有一个属于自己的独立空间并且一个进程最少有一个线程。
一个进程就是一个程序程序之间的切换会带来比较大的开销。并且进程之间不能共享堆和方法区的资源因此如果发生了进程之间的切换负担会比较大。
最最最重要的是进程是CPU资源分配的最小单位 3. 线程
线程是进程的一个执行任务控制单位负责当前进程中程序的执行。
一个进程最少有一个线程最多可以有很多的线程同一个进程内的多个线程可以共享数据它们可以共享方法区和堆内存每个线程都有它们自己的程序计数器、虚拟机栈、本地方法栈。
正是因为同一线程之间可以共享数据所以各个线程出现切换工作的时候这个代价比不同进程之间发生发生切换的代价要小。所以线程也被称为轻量级进程。
线程是CPU调度的最小单位。 4. 协程
协程也被称为微线程是用户态的轻量级的线程。
协程有自己的寄存器上下文和栈当协程调度切换的时候会将寄存器上下文和栈保存到其他地方在切换回来的时候可以恢复先前保存的寄存器上下文和栈。
因此协程可以保留上一次调用的状态每次过程重入的时候相当于进入上一次调用的状态。
协程最突出的优点就是高并发、高扩展性和低成本一个CPU可以支持上万个协程所以很适合用来做高并发处理。
协程的好处
无需线程上下文切换的开销无需原子操作锁定及同步的开销方便切换控制流简化编程模型
协程的坏处
无法利用多核资源协程的本质其实就是单线程所以它无法充分利用多核CPU的优势协程需要和进程配合才能运行在多CPU上。进行阻塞Blocking操作如IO时会阻塞掉整个程序 5. 进程与线程区别
根本区别进程是操作系统资源分配的基本单位而线程是处理器任务调度和执行的基本单位。资源开销每个进程都有独立的代码和数据空间程序上下文程序之间的切换会有较大的开销线程可以看做轻量级的进程同一类线程共享代码和数据空间每个线程都有自己独立的运行栈和程序计数器PC线程之间切换的开销小。包含关系如果一个进程内有多个线程则执行过程不是一条线的而是多条线线程共同完成的线程是进程的一部分所以线程也被称为轻权进程或者轻量级进程。内存分配同一进程的线程共享本进程的地址空间和资源而进程之间的地址空间和资源是相互独立的。影响关系一个进程崩溃后在保护模式下不会对其他进程产生影响但是一个线程崩溃整个进程都死掉。所以多进程要比多线程健壮。执行过程每个独立的进程有程序运行的入口、顺序执行序列和程序出口。但是线程不能独立执行必须依存在应用程序中由应用程序提供多个线程执行控制两者均可并发执行6. 参考 进程和线程的区别(超详细)_ThinkWon的博客-CSDN博客面试题线程与进程区别 - 腾讯云开发者社区-腾讯云