“不要通过共享内存来通信”——深入理解Golang并发模型与CSP理论

简介: Golang 采用 CSP 理念,主张“通过通信共享内存”,以消息传递替代共享内存,避免数据竞争。其核心为 Goroutine 与 Channel:轻量协程并发执行,通道安全传递数据,将并发复杂性转为通信编排,提升程序清晰度与可维护性。

Golang 在设计上另辟蹊径,其并发哲学的核心信条是:“不要通过共享内存来通信,而要通过通信来共享内存。” (Do not communicate by sharing memory; instead, share memory by communicating.) 这一理念源自通信顺序进程(Communicating Sequential Processes, CSP)理论。

共享消息模型
在共享消息模型(Show Message Model)中,线程或进程通过消息的发送与接收来实现通信与协同。这一模型的最大亮点在于,它能有效规避数据竞争及其他并发问题。原因在于,每个线程或进程都拥有独立的内存空间,无需借助锁或其他同步机制。
该模型的另一显著特征是,消息的发送与接收是异步进行的。这意味着,一个线程或进程在发出消息后,无需等待接收方处理,即可继续执行其他任务。这种异步特性极大地提升了并发性能,因为线程或进程不会因等待消息收发而陷入阻塞。
在该模型中,开发者的角色从“卫兵”转变为“流程设计师”或“编舞家”。他的核心任务不再是保护数据,而是设计高效、无误的数据流管道。通过精心编排数据在进程或线程间的流动顺序,隐式地构建了操作间的因果关系。
程序的确定性,并非来自于对资源的加锁,而是源于消息传递所建立的自然时序。这种模型将并发的复杂性从“管理状态”转移到了“编排通信”,使得并发逻辑更清晰,也更易于推理。
image.png

通信顺序进程
通信顺序进程(Communicating Sequential Process,CSP)是 Tony Hoare 在 1978 年提出的一种描述并发系统交互的模式,它正是Golang并发模型的灵感源泉。该模型强调通过通信来协调进程之间的交互,而不是共享数据。
CSP模型,包含进程(Process)‌和通道(Channel)‌两个概念。
1)进程:进程是并发系统中的基本执行单元。每个进程都有自己的独立执行流,并且通过通信进行交互。
‌ 2)通道:通道是进程之间进行通信的媒介。它可以看作是一个先进先出的队列,进程可以向通道发送消息或从通道接收消息。
当进程向通道中发送消息,如果通道已满,则发送操作会阻塞,直到通道有足够的空间;当进程从通道中接收消息,如果通道为空,则接收操作会阻塞,直到通道中有消息可用。
image.png

CSP模型的关键特性是,进程的执行不会受到其他进程的直接影响,进程间的交互仅通过通道发送和接收消息来实现。这意味着进程的内部状态对其他进程是不可见的,从而降低了并发编程的复杂性。
Golang通过轻量级的Goroutine和通信机制Channel,实现了CSP模型的核心思想,即通过消息传递而非共享内存实现并发控制。
1)Goroutine:Goroutine 是Golang的轻量级协程。创建一个新的 Goroutine 非常简单,只需在函数调用前加上关键字 go。由于 Goroutine 的创建和切换成本非常低,所以在 Golang中可以创建大量的 Goroutine 来处理并发任务。

// 通过关键字go,创建一个Goroutine并执行异步函数
go func() {
   
// todo
}()

2)Channel:Channel提供了一种在 Goroutine 之间进行通信的机制。可以从一个Goroutine将数据发送到 Channel,然后另一个 Goroutine 中从 Channel 接收这个数据。
在Golang中,Goroutine代表并发的实体,它们各自独立地执行任务;而Channel则用于在Goroutine之间传递消息,协调它们之间的工作。
image.png

未完待续很高兴与你相遇!

如果你喜欢本文内容,记得关注哦

目录
相关文章
|
Go 开发者
Go语言并发模型概览:CSP模型解析
【2月更文挑战第17天】Go语言以其强大的并发处理能力在编程领域崭露头角。其中,CSP(Communicating Sequential Processes)模型作为Go语言并发模型的核心之一,在并发编程中发挥着至关重要的作用。本文将深入解析CSP模型的基本原理及其在Go语言中的应用,帮助读者更好地理解Go语言的并发编程特性。
|
消息中间件 Linux
Linux中的System V通信标准--共享内存、消息队列以及信号量
希望本文能帮助您更好地理解和应用System V IPC机制,构建高效的Linux应用程序。
462 48
|
安全 Go 调度
解密Go语言并发模型:CSP与goroutine的魔法
在本文中,我们将深入探讨Go语言的并发模型,特别是CSP(Communicating Sequential Processes)理论及其在Go中的实现——goroutine。我们将分析CSP如何为并发编程提供了一种清晰、简洁的方法,并通过goroutine展示Go语言在处理高并发场景下的独特优势。
|
消息中间件 分布式计算 网络协议
从管道路由到共享内存:进程间通信的演变(内附通信方式经典面试题及详解)
进程间通信(Inter-Process Communication, IPC)是计算机科学中的一个重要概念,指的是运行在同一系统或不同系统上的多个进程之间互相发送和接收信息的能力。IPC机制允许进程间共享数据、协调执行流程,是实现分布式系统、多任务操作系统和并发编程的基础。
347 1
从管道路由到共享内存:进程间通信的演变(内附通信方式经典面试题及详解)
|
NoSQL Java 测试技术
Golang内存分析工具gctrace和pprof实战
文章详细介绍了Golang的两个内存分析工具gctrace和pprof的使用方法,通过实例分析展示了如何通过gctrace跟踪GC的不同阶段耗时与内存量对比,以及如何使用pprof进行内存分析和调优。
565 0
Golang内存分析工具gctrace和pprof实战
|
Kubernetes 网络协议 测试技术
记一次golang内存泄露
记一次golang内存泄露
163 4
|
Prometheus Cloud Native Java
解决golang 的内存碎片问题
解决golang 的内存碎片问题
255 3
|
存储 安全 Python
进程通信 , 信号量 , 队列 , 管道 , 共享内存
进程通信 , 信号量 , 队列 , 管道 , 共享内存
|
安全 Go 开发者
Golang深入浅出之-Go语言中的CSP模型:深入理解并发哲学
【5月更文挑战第2天】Go语言的并发编程基于CSP模型,强调通过通信共享内存。核心概念是goroutines(轻量级线程)和channels(用于goroutines间安全数据传输)。常见问题包括数据竞争、死锁和goroutine管理。避免策略包括使用同步原语、复用channel和控制并发。示例展示了如何使用channel和`sync.WaitGroup`避免死锁。理解并发原则和正确应用CSP模型是编写高效安全并发程序的关键。
379 7
|
安全 Go 开发者
Golang深入浅出之-Go语言中的CSP模型:深入理解并发哲学
【5月更文挑战第1天】Go语言基于CSP理论,借助goroutines和channels实现独特的并发模型。Goroutine是轻量级线程,通过`go`关键字启动,而channels提供安全的通信机制。文章讨论了数据竞争、死锁和goroutine泄漏等问题及其避免方法,并提供了一个生产者消费者模型的代码示例。理解CSP和妥善处理并发问题对于编写高效、可靠的Go程序至关重要。
547 2

推荐镜像

更多