Loading [MathJax]/jax/output/CommonHTML/config.js
前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
社区首页 >专栏 >Actor模型和CSP模型的区别

Actor模型和CSP模型的区别

作者头像
物流IT圈
发布于 2019-07-16 02:35:31
发布于 2019-07-16 02:35:31
1.7K0
举报
文章被收录于专栏:物流IT圈物流IT圈

  Akka/Erlang的actor模型与Go语言的协程Goroutine与通道Channel代表的CSP(Communicating Sequential Processes)模型有什么区别呢?

  首先这两者都是并发模型的解决方案,我们看看Actor和Channel这两个方案的不同:

Actor模型

  在Actor模型中,主角是Actor,类似一种worker,Actor彼此之间直接发送消息,不需要经过什么中介,消息是异步发送和处理的:

  Actor模型描述了一组为了避免并发编程的常见问题的公理:

  1.所有Actor状态是Actor本地的,外部无法访问。   2.Actor必须只有通过消息传递进行通信。     3.一个Actor可以响应消息:推出新Actor,改变其内部状态,或将消息发送到一个或多个其他参与者。   4.Actor可能会堵塞自己,但Actor不应该堵塞它运行的线程。

Channel模型

  Channel模型中,worker之间不直接彼此联系,而是通过不同channel进行消息发布和侦听。消息的发送者和接收者之间通过Channel松耦合,发送者不知道自己消息被哪个接收者消费了,接收者也不知道是哪个发送者发送的消息。

  Go语言的CSP模型是由协程Goroutine与通道Channel实现:

  • Go协程goroutine: 是一种轻量线程,它不是操作系统的线程,而是将一个操作系统线程分段使用,通过调度器实现协作式调度。是一种绿色线程,微线程,它与Coroutine协程也有区别,能够在发现堵塞后启动新的微线程。
  • 通道channel: 类似Unix的Pipe,用于协程之间通讯和同步。协程之间虽然解耦,但是它们和Channel有着耦合。

Actor模型和CSP区别

  Actor模型和CSP区别图如下:

  Actor之间直接通讯,而CSP是通过Channel通讯,在耦合度上两者是有区别的,后者更加松耦合。

  同时,它们都是描述独立的流程通过消息传递进行通信。主要的区别在于:在CSP消息交换是同步的(即两个流程的执行"接触点"的,在此他们交换消息),而Actor模型是完全解耦的,可以在任意的时间将消息发送给任何未经证实的接受者。由于Actor享有更大的相互独立,因为他可以根据自己的状态选择处理哪个传入消息。自主性更大些。

  在Go语言中为了不堵塞流程,程序员必须检查不同的传入消息,以便预见确保正确的顺序。CSP好处是Channel不需要缓冲消息,而Actor理论上需要一个无限大小的邮箱作为消息缓冲。

本文参与 腾讯云自媒体同步曝光计划,分享自微信公众号。
原始发表:2019-03-12,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 驼马精英 微信公众号,前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
暂无评论
推荐阅读
编辑精选文章
换一批
三分钟掌握Actor和CSP模型
前文传送门:《三分钟掌握共享内存模型和 Actor模型》, 一直想比较Actor模型与golang的CSP模型,经过一段时间的实战记录了本文。
有态度的马甲
2022/03/30
5650
三分钟掌握Actor和CSP模型
Actor模型
传统的游戏服务器要么是单线程要么是多线程,过去几十年里CPU一直遵循摩尔定律发展,带来的结果是单核频率越来越高。而近几年摩尔定义在CPU上已然失效,为什么呢?
spilledyear
2022/05/13
8800
Actor模型
Go 并发实战--协程浅析 二
继续上一篇的内容,我们介绍了go协程的实现中的几个核心的对象,也说了他们之间是如何合作工作的。
邹志全
2019/07/31
3180
面试必备(背)--Go语言八股文系列!
满足强三色不变性:黑色节点不允许引用白色节点 当黑色节点新增了白色节点的引用时,将对应的白色节点改为灰色
微客鸟窝
2021/11/12
6.4K0
面试必备(背)--Go语言八股文系列!
Go语言 | CSP并发模型与Goroutine的基本使用
今天是golang专题的第13篇文章,我们一起来聊聊golang当中的并发与Goroutine。
TechFlow-承志
2020/08/04
1.6K0
Go语言 | CSP并发模型与Goroutine的基本使用
并发模型比较
Golang 的特色之一就是 goroutine ,使得程序员进行并发编程更加方便,适合用来进行服务器编程。作为后端开发工程师,有必要了解并发编程面临的场景和常见的解决方案。一般情况下,是怎样做高并发的编程呢?有那些经典的模型呢?
Java知音
2018/09/21
2.1K0
并发模型比较
GoLang并发控制(上)
首先解释golang中的channel:channel是go中的核心部分之一,结构体简单概括就是一个ring队列+一个锁 有兴趣的同学可以去研究一下源码构建。在使用中可以将channel看做管道,通过channel迸发执行的go程之间就可以发送或者接受数据,从而对并发逻辑进行控制。
李海彬
2018/12/14
1.4K0
从鹅厂实例出发!分析Go Channel底层原理
本文是基于Go1.18.1源码的学习笔记。Channel的底层源码从Go1.14到现在的Go1.19之间几乎没有变化,这也是Go最早引入的组件之一,体现了Go并发思想: Do not communicate by sharing memory; instead, share memory by communicating. 不要通过共享内存来通信,⽽应通过通信来共享内存。 结论 还是先给出结论,没时间看分析过程的同学至少可以看一眼结论: 1. Channel本质上是由三个FIFO(First In Fi
腾讯云开发者
2022/11/29
3980
从鹅厂实例出发!分析Go Channel底层原理
深入分析Go1.18 Channel底层原理
由于Go Channel底层原理比较简单,源码也比较容易看懂,网上关于Channel源码分析的文章比较多,很多质量也都很高,本文主要是自己个人对于Channel源码的学习笔记。
涂明光
2022/09/28
2.5K0
Golang深入浅出之-Go语言中的CSP模型:深入理解并发哲学
在Go语言的世界里,并发编程是一门艺术,而这一切的核心便是Communicating Sequential Processes (CSP)模型。CSP模型由Tony Hoare提出,它强调通过通信来共享内存,而非直接访问,从而简化了并发程序的设计与实现。本文将深入浅出地探讨Go语言中的CSP模型,揭示其并发哲学,并指出常见问题、易错点及避免策略,辅以代码示例,帮助开发者更好地驾驭并发编程。
Jimaks
2024/05/02
6460
【Go 语言社区】golang协程——通道channel阻塞
说到channel,就一定要说一说线程了。任何实际项目,无论大小,并发是必然存在的。并发的存在,就涉及到线程通信。在当下的开发语言中,线程通讯主要有两种,共享内存与消息传递。共享内存一定都很熟悉,通过共同操作同一对象,实现线程间通讯。消息传递即通过类似聊天的方式。golang对并发的处理采用了协程的技术。golang的goroutine就是协程的实现。协程的概念很早就有,简单的理解为轻量级线程,goroutine就是为了解决并发任务间的通信而设计的。golang解决通信的理念是:不要通过共享内存来通信,而应
李海彬
2018/03/20
1.7K0
深度解密Go语言之channel
大家好啊!“深度解密 Go 语言”系列好久未见,我们今天讲 channel,预祝阅读愉快!在开始正文之前,我们先说些题外话。
梦醒人间
2019/07/23
1.1K0
深度解密Go语言之channel
Go 并发实战--管道浅析
在讲 channel 之前,有必要先提一下 CSP 模型,传统的并发模型主要分为 Actor模型和CSP模型,CSP 模型(communicating sequential processes)由并发执行实体(进程、线程或协程),和消息通道组成,实体之间通过消息通道发送消息进行通信。 和 Actor 模型不同,CSP 模型关注的是消息发送的载体,而不是发送消息的执行实体。Go 语言的并发模型就参考了 CSP 理论,其中执行实体对应的是go协程,消息通道指的就是channel。
邹志全
2019/07/31
9140
基于 CSP 的设计思想和 OOP 设计思想的异同
Go语言推崇的CSP编程模型和设计思想,并没有引起很多Go开发者包括Go标准库作者的重视。标准库的很多设计保留了很浓的OOP的味道。本篇Blog想比较下从设计的角度看,CSP和OOP到底有什么区别。 下面,我们来看一个例子,如果我们有一个项目,需要做一个TCP连接中继器(请原谅我的用词)。我们先按照OOP来设计下: 系统的结构:需要有一个客户端和一个服务器端。分两个进程分别跑在不同机器上。 系统对象关系拆分(这里有所简化,E-R图等省略):连接中继器类--系统的主类、config类--描述配置的类、conn
Linker
2018/04/13
1.3K0
Go Channel(收藏以备面试)
Go语言采用CSP模型,让两个独立执行的程序通过消息传递的方式共享内存,Channel就是Golang用来完成消息通讯的数据类型。
一行舟
2022/08/25
4910
听GPT 讲Go源代码--chan.go
chan.go这个文件是Go语言标准库中的一个重要文件,它实现了Go语言中的通道(channel)机制。
fliter
2023/06/18
2520
听GPT 讲Go源代码--chan.go
channel
单纯地将函数并发执行是没有意义的。函数与函数间需要交换数据才能体现并发执行函数的意义。
Michel_Rolle
2023/11/30
2.6K0
Operating System 13 - 并发编程范式
并发编程的源头是在于内存中的数据需要在不同的线程之间共享, 因为多线程程序在运行时存在交错(interleaving).
Reck Zhang
2021/08/11
5770
Operating System 13 - 并发编程范式
为什么这段代码会阻塞?
2. 这段代码开启了一个 goroutine,这个goroutine会向 in 通道中放入2000个 Content 对象,每个对象的 i 字段从0到1999。每放入一个对象都会记录日志。
腾讯云开发者
2024/09/10
3530
为什么这段代码会阻塞?
字节跳动的 Go 语言面试会问哪些问题?
这个一般分为两个层次,初中级开发(1-1、1-2)和高级开发(2-1、2-2),不同级别的面试一般要求是不一样的。对于初中级开发,一般会问一些语言层面的东西,一些常用的基础原理和一些算法,但是高级开发就没那么简单了。下面我为读者分享一段面试的经历。
肉眼品世界
2020/11/11
3.4K0
相关推荐
三分钟掌握Actor和CSP模型
更多 >
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档