iis服务器助手广告广告
返回顶部
首页 > 资讯 > 后端开发 > GO >golang协程与线程区别简要介绍
  • 373
分享到

golang协程与线程区别简要介绍

2024-04-02 19:04:59 373人浏览 安东尼
摘要

目录一、进程与线程二、并发与并行三、Go协程与线程1.调度方式2.调度策略3.上下文切换速度4.栈的大小四、GMP模型一、进程与线程 进程是操作系统资源分配的基本单位,是程序运行的实

一、进程与线程

进程是操作系统资源分配的基本单位,是程序运行的实例。例如打开一个浏览器就开启了一个进程。

线程是操作系统调度到CPU中执行的基本单位。例如在浏览器里新建一个窗口就需要一个线程来进行处理。

在一般情况下,线程是进程的组成部分,一个进程可以包含多个线程。例如浏览器可以新建多个窗口。

进程中的多个线程并发执行并共享进程的内存等资源。例如多个窗口之间可以共享登录状态、cookie等信息。

进程之间相对独立,不同进程具有不同的内存地址空间,系统资源描述符等。例如再新开一个浏览器,就又开启了一个进程,浏览器之间状态相互独立。

开启一个进程的开销比开启一个线程大得多,且进程具有独立的内存空间,多进程之间的通信通常比较困难。

二、并发与并行

并发不等于并行。

并发并不意味着同一时刻所有任务都在执行,而是在一个时间段内,所有的任务都能执行完毕。例如在单核CPU上运行多线程程序,多线程会交替抢占CPU时间片,任意一个时刻只能执行一个具体的线程。

在多核CPU上,线程可以分布在多个CPU核心上运行,实现真正的并行处理。

在多核处理场景中,并发与并行往往同时存在,多核心在并行处理多个线程,单核心中的多个线程又在交替执行。

三、go协程与线程

线程是系统调度的基本单位。go协程由go语言运行时的调度器进行调度,操作系统内核感知不到协程的存在。

在多核处理场景中,线程是并发与并行同时存在的,而go协程依托于线程,因此多核处理场景下,go协程也是并发与并行同时存在的。因为go协程从属于某一个线程,所以即便在单核处理器上某一时刻运行一个线程,在线程内go语言调度器也会切换多个协程执行,这时协程是并发的。在多核心处理器上,如果多个协程被分配给了不同的线程,而这些线程同时被不同的CPU核心所处理,这时协程就是并行处理的。

go协程与线程存在着很多不同之处:

1.调度方式

线程: 线程是根据CPU时间片进行抢占式调度的。操作系统通过中断信号(定时器中断、I/O设备中断等)执行线程的上下文切换。当发生线程上下文切换时,需要从操作系统用户态转移到内核态,并保存状态信息;当切换到下一个要执行的线程时,需要加载状态信息并从内核态转移到操作系统用户态。

协程: 协程存在于用户态,由go语言运行时调度器进行调度。协程从属于某一个线程,多个协程可以调度到一个线程中,一个协程也可能切换到多个线程中执行,因此协程与线程是多对多(M:N)的关系。

2.调度策略

  • 线程抢占式调度。操作系统调度器为了均衡每个线程的执行周期,会定时发出中断信号强制执行线程上下文切换。
  • 协程协作式调度。一个协程处理完自己的任务后,可以主动将执行权限让渡给其他协程,不会被轻易抢占。只有在协程运行了过长时间后,go语言调度器才会强制抢占其执行。

3.上下文切换速度

线程: 线程上下文的切换需要经过操作系统用户态与内核态的切换,切换速度大约为1~2微秒。

协程: 协程属于用户态轻量级的线程,协程的切换不需要经过用户态与内核态的切换,且切换时只需要保存极少的状态值,因此切换速度快数倍,大约为0.2微秒左右。(大约10倍于线程的切换速度)

4.栈的大小

线程: 线程的栈大小一般是在创建时指定的,linuxMac上默认的栈大小一般为8MB(可以通过ulimit -s查看)。2000个线程需要消耗16G虚拟内存。

协程: go协程栈大小默认为2KB, 16G虚拟内存可以创建800多万个协程。在实践中,经常可以看到存在成千上万的协程。

四、GMP模型

协程(G)线程(M)逻辑处理器(P)模型描述了线程与协程的关系。在GMP模型中:

G代表go协程(Goroutine),M代表实际的线程,P代表逻辑处理器(Process)。go语言为了方便协程的调度与缓存,抽象出了逻辑处理器P

在任一时刻,一个逻辑处理器P可能在本地包含多个协程G,同时绑定一个线程M。需要注意的是,一个协程G并不是固定绑定同一个逻辑处理器P的,可能转移到其他逻辑处理器中。

逻辑处理器P对应的线程M也是不固定的,在某些时候可能转移到其他P中执行。

image.png

到此这篇关于golang协程与线程区别简要介绍的文章就介绍到这了,更多相关golang协程与线程 内容请搜索编程网以前的文章或继续浏览下面的相关文章希望大家以后多多支持编程网!

您可能感兴趣的文档:

--结束END--

本文标题: golang协程与线程区别简要介绍

本文链接: https://www.lsjlt.com/news/152910.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • golang协程与线程区别简要介绍
    目录一、进程与线程二、并发与并行三、go协程与线程1.调度方式2.调度策略3.上下文切换速度4.栈的大小四、GMP模型一、进程与线程 进程是操作系统资源分配的基本单位,是程序运行的实...
    99+
    2024-04-02
  • Golang中线程与协程的区别及应用
    Golang中线程与协程的区别及应用 Golang是一种开发效率高、并发性能强大的编程语言,其中线程(goroutine)和协程(thread)是其并发编程的关键概念。在Golang中...
    99+
    2024-02-29
    golang 线程 协程 go语言
  • golang中协程与线程的区别是什么
    golang中协程与线程的区别有”调度器“、”内存和性能“、”锁和同步“和”异常处理“四点:1、协程则是由 Go 语言运行时调度的,而线程是由操作系统内核调度的;2、协程在相同的堆栈空间内运行,而线程都需要独立的堆栈空间和上下文切换的开销;...
    99+
    2023-12-12
    Golang golang线程 Golang协程
  • Golang 协程 / 线程 / 进程 区别详解
    概念进程 每个进程都有自己的独立内存空间,拥有自己独立的地址空间、独立的堆和栈,既不共享堆,亦不共享栈。一个程序至少有一个进程,一个进程至少有一个线程。进程切换只发生在内核态。线程 线程拥有自己独立的栈和共享的堆,共享堆,不共享栈,是由操作...
    99+
    2023-06-08
    Go istio k8s 云原生
  • golang协程区别
    Go语言是近年来备受关注的一门编程语言。其特有的并发编程方式和协程机制被广泛应用在Web开发、系统编程、网络通讯等领域。在Go语言中,协程是一种轻量级的线程,由Go语言运行时管理,可以在程序中并发执行任务。在Go语言中,协程是“go”关键字...
    99+
    2023-05-15
  • golang中线程和协程有哪些区别
    这篇文章主要介绍golang中线程和协程有哪些区别,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!区别:线程中数据存储在内核态的内存空间;而协程中数据存储在线程提供的用户态内存空间。线程的任务调度由内核实现,抢占方式,...
    99+
    2023-06-14
  • python协程与golang协程的区
    进程、线程和协程 进程的定义: 进程,是计算机中已运行程序的实体。程序本身只是指令、数据及其组织形式的描述,进程才是程序的真正运行实例。 线程的定义: 操作系统能够进行运算调度的最小单位。它被包含在进程之中,是进程中的实际运作单位。 进程...
    99+
    2023-01-31
    python golang
  • golang线程池和协程池有什么区别
    Golang中没有线程池的概念,而是通过协程(goroutine)来实现并发。协程是一种轻量级的线程,由Go语言的运行时环境(run...
    99+
    2023-10-26
    golang
  • Java线程间共享与协作详细介绍
    目录线程的共享synchronized内置锁错误的加锁和原因分析volatile,最轻量的同步机制ThreadLocal与 Synchonized的比较ThreadLocal的使用实...
    99+
    2024-04-02
  • C#线程的简单介绍
    本篇内容介绍了“C#线程的简单介绍”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!C#线程是什么呢?在操作系统中一个进程至少要包含一个线程,然...
    99+
    2023-06-17
  • Kotlin协程flowOn与线程切换超详细示例介绍
    目录示例代码一.flowOn方法1.ChannelFlowOperatorImpl类二.collect方法1.ChannelFlowOperator类的collect方法2.Chan...
    99+
    2024-04-02
  • C#中异步和多线程的区别介绍
    一、区别和联系 异步和多线程有什么区别?其实,异步是目的,而多线程是实现这个目的的方法。异步是说,A发起一个操作后(一般都是比较耗时的操作,如果不耗时的操作就没有必要异步了),可以继...
    99+
    2024-04-02
  • go语言中协程与线程的区别有哪些
    这篇文章主要介绍“go语言中协程与线程的区别有哪些”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“go语言中协程与线程的区别有哪些”文章能帮助大家解决问题。区别:1、一个线程可以多个协程,一个进程也可...
    99+
    2023-07-05
  • go语言中协程与线程的区别是什么
    区别:1、一个线程可以多个协程,一个进程也可以单独拥有多个协程;2、线程是同步机制,而协程则是异步;3、协程能保留上一次调用时的状态,线程不行;4、线程是抢占式,协程是非抢占式的;5、线程是被分割的CPU资源,协程是组织好的代码流程,协程需...
    99+
    2023-05-14
    Golang go语言 协程 线程
  • go协程和线程有什么区别
    Go协程和线程是两种并发执行的机制,它们有以下几个主要区别:1. 调度器:Go协程由Go语言的运行时调度器(Goroutine Sc...
    99+
    2023-10-20
    go
  • 协程和线程的区别和联系
    本篇内容介绍了“协程和线程的区别和联系”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!进程进程是什么进程是操作系统对一个正在运行的程序的一种抽...
    99+
    2023-06-15
  • Golang工程师的岗位要求与技能介绍
    Golang工程师的岗位要求与技能介绍 随着互联网行业的快速发展,Golang作为一种高效、简洁、并发性能较高的编程语言,逐渐受到了越来越多公司的青睐。因此,对于具备Golang技能的...
    99+
    2024-04-02
  • shell 多线程介绍与举例
    在Shell脚本中实现多线程通常可以使用以下几种方式: 后台执行:在Shell脚本中,你可以使用&符号将某个命令放在后台执行,这样可以同时执行多个命令,达到多线程的效果。例如: #!/bin/bashcommand1 &command2 &...
    99+
    2023-08-21
    linux bash 服务器
  • go协程和线程的区别有哪些
    Go协程和线程之间有以下几个主要区别:1. 轻量级:Go协程是由Go运行时管理的轻量级线程。一个应用程序可以同时运行成千上万个协程,...
    99+
    2023-08-31
    go
  • 关于MVC与SpringMVC的介绍、区别、执行流程
    目录介绍区别两者执行流程MVC执行流程:Spring MVC执行流程:介绍 MVC(Model-View-Controller)是一种软件架构模式,其中应用程序被划分为三个部分:模型...
    99+
    2023-05-19
    MVC SpringMVC区别 SpringMVC执行流程
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作