Golang的CSP模型讲解

一.CSP是什么

CSP 是 Communicating Sequential Process 的简称,中文可以叫做通信顺序进程,是一种并发编程模型,是一个很强大的并发数据模型,是上个世纪七十年代提出的,用于描述两个独立的并发实体通过共享的通讯channel(管道-用于传输和同步数据)进行通信的并发模型 ,在CSP模型中,每个并发执行的任务都是独立的,它们之间不会共享同一块内存空间,而是通过通信来进行数据交换和协调,相对于Actor模型,CSP中channel是第一类对象,它不关注发送消息的实体,而关注与发送消息时使用的channel,严格来说,CSP 是一门形式语言(类似于 ℷ calculus),用于描述并发系统中的互动模式,也因此成为一众面向并发的编程语言的理论源头,并衍生出了 Occam/Limbo/Golang...

而具体到编程语言,如 Golang,其实只用到了 CSP 的很小一部分,即理论中的 Process/Channel(对应到语言中的 goroutine/channel):这两个并发原语之间没有从属关系, Process 可以订阅任意个 Channel,Channel 也并不关心是哪个 Process 在利用它进行通信,Process 围绕 Channel 进行读写,形成一套有序阻塞可预测的并发模型

二.Golang的CSP模型

与主流语言通过共享内存来进行并发控制方式不同 ,Go语言采用了 CSP 模式,这是一种用于描述两个独立的并发实体通过共享的通讯Channel(管道)进行通信的并发模型 ,Go 就是借用CSP模型的一些概念为之实现并发进行理论支持,其实从实际上出发,go语言并没有,完全实现了CSP模型的所有理论,仅仅是借用了 process和channel这两个概念 ,process是在Go语言上的表现就是goroutine,是实际并发执行的实体,每个实体之间是通过channel通讯来实现数据共享,Go并发的核心哲学是:不要通过共享内存来通信,而应该通过通信来共享内存,从以上描述可知:Go语言的CSP模型是由协程goroutine管道channel实现的:

有了channel和goroutine之后,Go 的并发编程变得异常容易和安全,得以让程序员把注意力留到业务上去,实现开发效率的提升
以上就是Go语言中的独立并发执行(CSP)模型的详细内容

相关推荐
IT_陈寒几秒前
SpringBoot 3.2 实战:用这5个新特性让你的API性能提升40%
前端·人工智能·后端
一过菜只因4 分钟前
JavaWeb后端(spring--boot)
java·开发语言
五仁火烧9 分钟前
安装rust开发环境
开发语言·后端·rust
IT枫斗者14 分钟前
Netty的原理和springboot项目整合
java·spring boot·后端·sql·科技·mysql·spring
Yue丶越15 分钟前
【C语言】动态内存管理
c语言·开发语言
Edward1111111117 分钟前
普通java项目转为maven项目 J文件后缀.java变C文件
java·开发语言·maven
赵谨言17 分钟前
基于OpenCV的图像梯度与边缘检测研究
大数据·开发语言·经验分享·python
Java程序之猿25 分钟前
Springboot 集成apache-camel +mqtt 根据主题处理mqtt消息
java·spring boot·后端
莓莓儿~32 分钟前
Next.js 14 App Router数据获取开发手册
开发语言·前端·javascript
wjs202432 分钟前
ionic 单选框详解
开发语言