返回顶部
首页 > 资讯 > 后端开发 > GO >GolangCSP并发机制及使用模型
  • 407
分享到

GolangCSP并发机制及使用模型

2024-04-02 19:04:59 407人浏览 八月长安
摘要

目录CSP并发模型golang CSPChannelGoroutineGoroutine 调度器总结今天介绍一下 go语言的并发机制以及它所使用的CSP并发模型 CSP并发模型 CS

今天介绍一下 go语言的并发机制以及它所使用的CSP并发模型

CSP并发模型

CSP模型是上个世纪七十年代提出的,用于描述两个独立的并发实体通过共享的通讯 channel(管道)进行通信的并发模型。 CSP中channel是第一类对象,它不关注发送消息的实体,而关注与发送消息时使用的channel。

Golang CSP

Golang 就是借用CSP模型的一些概念为之实现并发进行理论支持,其实从实际上出发,go语言并没有,完全实现了CSP模型的所有理论,仅仅是借用了 process和channel这两个概念。process是在go语言上的表现就是 goroutine 是实际并发执行的实体,每个实体之间是通过channel通讯来实现数据共享。

Channel

Golang中使用 CSP中 channel 这个概念。channel 是被单独创建并且可以在进程之间传递,它的通信模式类似于 boss-worker 模式的,一个实体通过将消息发送到channel 中,然后又监听这个 channel 的实体处理,两个实体之间是匿名的,这个就实现实体中间的解耦,其中 channel 是同步的一个消息被发送到 channel 中,最终是一定要被另外的实体消费掉的,在实现原理上其实是一个阻塞的消息队列

Goroutine

Goroutine 是实际并发执行的实体,它底层是使用协程(coroutine)实现并发,coroutine是一种运行在用户态的用户线程,类似于 greenthread,go底层选择使用coroutine的出发点是因为,它具有以下特点:

  • 用户空间 避免了内核态和用户态的切换导致的成本
  • 可以由语言和框架层进行调度
  • 更小的栈空间允许创建大量的实例

可以看到第二条 用户空间线程的调度不是由操作系统来完成的,像在java 1.3中使用的greenthread的是由JVM统一调度的(后java已经改为内核线程),还有在ruby中的fiber(半协程) 是需要在重新中自己进行调度的,而goroutine是在golang层面提供了调度器,并且对网络io库进行了封装,屏蔽了复杂的细节,对外提供统一的语法关键字支持,简化了并发程序编写的成本。

Goroutine 调度器

上节已经说了,golang使用goroutine做为最小的执行单位,但是这个执行单位还是在用户空间,实际上最后被处理器执行的还是内核中的线程,用户线程和内核线程的调度方法有:

N:1 多个用户线程对应一个内核线程

1:1 一个用户线程对应一个内核线程

M:N 用户线程和内核线程是多对多的对应关系

golang 通过为goroutine提供语言层面的调度器,来实现了高效率的M:N线程对应关系

调度示意

图中

  • M:是内核线程
  • P : 是调度协调,用于协调M和G的执行,内核线程只有拿到了 P才能对goroutine继续调度执行,一般都是通过限定P的个数来控制golang的并发度
  • G : 是待执行的goroutine,包含这个goroutine的栈空间
  • Gn : 灰色背景的Gn 是已经挂起的goroutine,它们被添加到了执行队列中,然后需要等待网络IO的goroutine,当P通过 epoll查询到特定的fd的时候,会重新调度起对应的,正在挂起的goroutine。

Golang为了调度的公平性,在调度器加入了steal working 算法 ,在一个P自己的执行队列,处理完之后,它会先到全局的执行队列中偷G进行处理,如果没有的话,再会到其他P的执行队列中抢G来进行处理。

总结

Golang实现了 CSP 并发模型做为并发基础,底层使用goroutine做为并发实体,goroutine非常轻量级可以创建几十万个实体。实体间通过 channel 继续匿名消息传递使之解耦,在语言层面实现了自动调度,这样屏蔽了很多内部细节,对外提供简单的语法关键字,大大简化了并发编程的思维转换和管理线程的复杂性。

以上就是Golang CSP并发机制及使用模型的详细内容,更多关于Golang CSP并发模型的资料请关注编程网其它相关文章!

您可能感兴趣的文档:

--结束END--

本文标题: GolangCSP并发机制及使用模型

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

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

猜你喜欢
  • GolangCSP并发机制及使用模型
    目录CSP并发模型Golang CSPChannelGoroutineGoroutine 调度器总结今天介绍一下 go语言的并发机制以及它所使用的CSP并发模型 CSP并发模型 CS...
    99+
    2024-04-02
  • Golang CSP并发机制及使用模型是什么
    这篇文章主要介绍了Golang CSP并发机制及使用模型是什么的相关知识,内容详细易懂,操作简单快捷,具有一定借鉴价值,相信大家阅读完这篇Golang CSP并发机制及使用模型是什么文章都会有所收获,下面我们一起来看看吧...
    99+
    2023-06-30
  • golang并发模型怎么使用
    Golang的并发模型是通过goroutine和channel来实现的。1. Goroutine: Goroutine是轻量级的线程...
    99+
    2023-08-23
    golang
  • Golang 进程控制:深入了解并发模型
    go 中的并发模型基于轻量级线程 goroutine,通过 go 关键字创建,由运行时调度。通道用于 goroutine 间通信,而 waitgroup 和互斥锁用于协调并发执行。实战案...
    99+
    2024-04-03
    golang 进程控制 并发访问
  • Nginx中如何使用limit模块限制并发数
    小编给大家分享一下Nginx中如何使用limit模块限制并发数,希望大家阅读完这篇文章之后都有所收获,下面让我们一起去探讨吧! nginx 限制ip并发数,nginx限制IP连接数的范例参考:如何Nginx限制同一个ip的连接数,限制并发数...
    99+
    2023-06-04
  • 机器学习:学习KMeans算法,了解模型创建、使用模型及模型评价
    机器学习:学习KMeans算法,了解模型创建、使用模型及模型评价 作者:i阿极 作者简介:Python领域新星作者、多项比赛获奖者:博主个人首页 😊😊😊如果觉得文章不错或能帮助到你学习,可以点...
    99+
    2023-08-31
    机器学习 python kmeans 算法
  • 常用的golang并发模型有哪些
    常用的golang并发模型有以下几种: Goroutine和Channel:Goroutine是轻量级的线程,可以同时运行上千个...
    99+
    2023-10-23
    golang
  • Go 并发编程协程及调度机制详情
    目录协程的概念goroutine 的诞生使用 goroutine 加快速度goroutine 的机制原理前言: 协程(coroutine)是 Go 语言最大的特色之一,gorouti...
    99+
    2024-04-02
  • 探讨使用Go实现类似于Erlang的并发模型
    Erlang 是一种功能强大的编程语言。它非常适合用于并发编程和分布式系统。Erlang 的设计目的是为了构建可靠的、容错的系统。而 Go 语言是一种简单高效的语言,它在开发网络应用程序时非常方便。本文我们将探讨使用 Go 语言实现 Erl...
    99+
    2023-05-14
  • C#中如何使用异步编程模型和并发集合处理并发问题
    C#中如何使用异步编程模型和并发集合处理并发问题引言:在现代软件开发中,处理并发问题是一个很常见的需求。并发问题指的是多个线程或任务同时访问共享资源,可能导致数据竞争、线程冲突等问题。C#语言提供了异步编程模型和并发集合等工具来帮助我们处理...
    99+
    2023-10-22
    并发集合 异步编程模型 处理并发问题
  • 常用的golang并发模型有哪几种
    常用的Golang并发模型有以下几种: 传统的多线程模型:基于线程和锁的并发模型,通过创建多个线程来处理并发任务,并使用锁来保护...
    99+
    2024-02-29
    golang
  • Golang常用的并发控制机制有哪些
    Goroutines:Goroutines 是 Golang 中的轻量级线程,可以并发地执行函数或方法。 Channels:...
    99+
    2024-03-13
    Golang
  • C#中如何使用异步任务和并发编程模型
    C#中如何使用异步任务和并发编程模型,需要具体代码示例在C#编程语言中,异步任务和并发编程模型是非常重要的概念和技巧。它们可以帮助我们更好地利用计算资源,提高程序的性能和响应能力。本文将介绍C#中如何使用异步任务和并发编程模型,并提供具体的...
    99+
    2023-10-22
    C# 并发编程 异步任务
  • Go语言CSP并发模型goroutine及channel底层实现原理
    目录Go的CSP并发模型(goroutine + channel)1、goroutinegoroutine的优点:2、channel无缓存channel有缓存channel3、Go并...
    99+
    2024-04-02
  • C#中如何使用异步编程模型和并发编程处理任务分发及解决方法
    C#中如何使用异步编程模型和并发编程处理任务分发及解决方法引言:在现代的软件开发中,我们经常面临处理大量任务的情况,而这些任务可能是独立的,互不干扰的。为了提高程序的性能和效率,我们希望能够并发地处理这些任务,并且在每个任务完成时能够得到相...
    99+
    2023-10-22
    并发编程 异步编程 任务分发
  • 使用Golang的锁机制实现高性能并发处理
    在Golang中,锁机制主要通过`sync`包来实现。`sync`包提供了多种锁类型,如互斥锁(`Mutex`)、读写锁(`RWMu...
    99+
    2023-10-09
    Golang
  • 分析Go语言中CSP并发模型与Goroutine的基本使用
    目录一、并发实现模型1.1、多进程1.2、多线程1.3、协程二、共享内存与CSP三、Goroutine一、并发实现模型 1.1、多进程 在之前的文章当中我们曾经介绍过,进程是操作系统...
    99+
    2024-04-02
  • C#中如何使用并发编程模型处理异步任务
    C#中如何使用并发编程模型处理异步任务,需要具体代码示例引言:在日常的软件开发中,处理异步任务是非常常见的需求。在C#中,我们可以使用并发编程模型来处理异步任务,提高程序的性能和响应能力。本文将介绍C#中的并发编程模型以及如何使用它来处理异...
    99+
    2023-10-22
    异步任务处理 并发编程模型 C#语言
  • C#代替go采用的CSP并发模型实现
    目录CSP(Communicating sequential processes)在Go中的CSP协程(提升并发的利器)线程线程的开销回归协程协程的目的C#中的协程C#中的CSPGo...
    99+
    2024-04-02
  • GO并发控制库Concurrency怎么使用
    这篇文章主要介绍“GO并发控制库Concurrency怎么使用”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“GO并发控制库Concurrency怎么使用”文章能帮助大家解决问题。Concurrenc...
    99+
    2023-07-04
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作