scala的akka和go的goroutine有什么区别

区别:goroutine实现的是csp,通过独立的channel传递信息。akka实现的是actor,消息通过actor拥有mailbox接收。akka是通过线程池实现的actor,线程是有限的,而goroutine运行在用户态线程上,受go运行时抢占式调度。二者都是通过消息通信的机制来避免竞态条件,但具体的抽象和实现上有些差异。

scala的akka和go的goroutine有什么区别-Worktile社区

goroutine实现的是csp,通过独立的channel传递信息。akka实现的是actor,消息通过actor拥有mailbox接收。

仅仅上面的不够特化。akka是通过线程池实现的actor,线程是有限的,假如一个actor阻塞一个线程(例如一个阻塞io),可能会影响其他的actor,类似于协调型的调度。而goroutine运行在用户态线程上,受go运行时抢占式调度。

二者都是通过消息通信的机制来避免竞态条件,但具体的抽象和实现上有些差异。

CSP模型里消息和Channel是主体,处理器是匿名的。

也就是说发送方需要关心自己的消息类型以及应该写到哪个Channel,但不需要关心谁消费了它,以及有多少个消费者。Channel一般都是类型绑定的,一个Channel只写同一种类型的消息,所以CSP需要支持alt/select机制,同时监听多个Channel。Channel是同步的模式(Golang的Channel支持buffer,支持一定数量的异步),背后的逻辑是发送方非常关心消息是否被处理,CSP要保证每个消息都被正常处理了,没被处理就阻塞着。

Actor模型里Actor是主体,Mailbox(类似于CSP的Channel)是透明的。也就是说它假定发送方会关心消息发给谁消费了,但不关心消息类型以及通道。所以Mailbox是异步模式,发送者不能假定发送的消息一定被收到和处理。Actor模型必须支持强大的模式匹配机制,因为无论什么类型的消息都会通过同一个通道发送过来,需要通过模式匹配机制做分发。它背后的逻辑是现实世界本来就是异步的,不确定(non-deterministic)的,所以程序也要适应面对不确定的机制编程。自从有了并行之后,原来的确定编程思维模式已经受到了挑战,而Actor直接在模式中蕴含了这点。

延伸阅读:

什么是go?

Go(又称 Golang)是 Google 的 Robert Griesemer,Rob Pike 及 Ken Thompson 开发的一种静态强类型、编译型语言。Go 语言语法与 C 相近,但功能上有:内存安全,GC(垃圾回收),结构形态及 CSP-style 并发计算。

Go(又称Golang)是Google开发的一种静态强类型、编译型、并发型,并具有垃圾回收功能的编程语言。

罗伯特·格瑞史莫(Robert Griesemer),罗布·派克(Rob Pike)及肯·汤普逊(Ken Thompson)于2007年9月开始设计Go,稍后Ian Lance Taylor、Russ Cox加入项目。Go是基于Inferno操作系统所开发的。Go于2009年11月正式宣布推出,成为开放源代码项目,并在Linux及Mac OS X平台上进行了实现,后来追加了Windows系统下的实现。在2016年,Go被软件评价公司TIOBE 选为“TIOBE 2016 年优异语言”。 目前,Go每半年发布一个二级版本(即从a.x升级到a.y)。

文章标题:scala的akka和go的goroutine有什么区别,发布者:小编,转载请注明出处:https://worktile.com/kb/p/38585

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
小编小编认证作者
上一篇 2023年2月17日 上午2:25
下一篇 2023年2月17日 上午2:27

相关推荐

  • java编程用什么软件

    摘要 在进行Java编程时,广泛推荐使用的软件包括1、IntelliJ IDEA、2、Eclipse、3、NetBeans。其中,IntelliJ IDEA因其出色的智能代码助手、高效的代码分析流程以及对现代化Java开发的全面支持而脱颖而出。IntelliJ IDEA不仅提供了一个强大的编码环境,…

    2024年4月25日
    1700
  • vscode为什么显示不出图片

    VSCode显示不出图片的主要原因可能包括:图片路径错误、文件格式不支持、插件冲突或设置问题。比如,如果图片存储的绝对或相对路径错误就无法正确加载,VSCode支持的图片格式要求(如JPEG、PNG等)如果不满足也会导致显示失败。同时,安装了某些插件后可能与内置的图片预览功能发生冲突,或是用户设置中…

    2024年4月3日
    28400
  • Java中的错误处理和日志记录方法有哪些

    Java在错误处理上采取了结构化异常处理框架,通过使用try-catch-finally语句以及抛出Throwable子类对象来管理错误。Java异常管理包含两类异常:1、检查型异常;2、非检查型异常。其中,检查型异常是方法在可能出现问题时必须进行处理的异常,使得开发者必须考虑错误处理策略。日志记录…

    2024年1月8日
    26300
  • 物业管理哪些项目

    物业管理覆盖的关键项目有1、保安服务,2、卫生清洁,3、绿化养护,4、设施维护,5、客户服务以及6、应急处理。在所有项目中,卫生清洁 十分关键,它直接反映了物业管理的水平和质量,涉及日常的清扫、垃圾处理、公共区域的保洁以及定期的大扫除活动。维持环境的清洁不仅有助于构建舒适的居住或工作环境,还能预防疾…

    2024年1月8日
    33300
  • 网站编程是干什么的

    网站编程是用来创建和维护网站的过程,主要包括网页设计、内容发展、客户端/服务器端脚本编写和网络安全配置五个方面。 网站编程的核心工作是编写代码和脚本,以实现网站的功能和交互。例如,在构建一个电子商务网站时,会通过编程实现商品展示、购物车管理、在线支付等功能。开发人员通常使用HTML、CSS、Java…

    2024年4月26日
    700
  • 公益性项目如何管理

    对于公益性项目的管理,关键在于细致规划、精确执行、有效沟通、合理分配资源、及时监督、透明财务等方面。精确执行是他们中的核心,因为它确保每一个环节按照既定计划进行,从而确保项目目标的达成。精确执行涉及对计划的遵守、时间管理、任务分配和质量控制等方面。它要求项目管理者能够严格遵循项目计划,在预定的时间内…

    2024年4月10日
    4200
  • 研发管控体系

    标题:研发管控体系 摘要:研发管控体系编排科技企业如何高效创新的框架,是指挥科研活动、保证产品质量与创新节奏的关键机制。该体系涉及多维度策略,主要包括1、战略定位清晰化,2、流程与方法优化,3、质量控制严格化,4、资源配置合理化,5、风险管理系统化。特别是在质量控制方面,精细化管理和持续改进是核心内…

    2024年1月9日
    20200
  • 装饰项目如何管理好

    要有效管理装饰项目,关键在于规划周详、精确控制时间线、质量监控、成本管理、以及良好的沟通机制。其中,规划周详是基石性的工作,它直接影响到项目的顺利进行和最终品质。好的规划包括明确项目目标、详细的施工方案、合理的时间安排和预算编制。这需要项目管理者具有前瞻性与细致的观察能力,以确保在项目启动之前,所有…

    2024年4月10日
    7300
  • 电力公司oa系统

    探讨电力公司办公自动化系统(OA System)的必要性和带来的效益,涵括了系统集成、提升效率、数据安全、成本节约、环境友好。第一个要点为OA系统大幅提升了工作流程的效率,通过自动排程和资源优化得到业界的广泛认可。 电力企业作为高度技术密集型的行业,对效率和精确性的需求极高。从一个侧面而言,OA系统…

    2024年1月15日
    28200
  • plc 用什么编程软件

    PLC编程主要应用的软件包括1、RSLogix 5000、2、Siemens STEP 7、3、CX-Programmer。 在这些软件中,Siemens STEP 7因其广泛的应用和强大的功能成为行业的佼佼者。Siemens STEP 7为编程人员提供了一个综合性的解决方案,从项目的设计和测试到最…

    2024年4月26日
    600

发表回复

登录后才能评论
注册PingCode 在线客服
站长微信
站长微信
电话联系

400-800-1024

工作日9:30-21:00在线

分享本页
返回顶部