Erlang的Actor回顾:将消息转化为逻辑执行

开发 开发工具
本文回顾了Erlang的Actor是如何将根据消息而选择逻辑分支的。

Erlang的Actor:根据消息模式选择逻辑分支

在Erlang中,一个消息往往为一个元组,而一个Actor便会根据这个消息的模式,或者用更通俗的方式来讲,“结构”,来选择处理消息的逻辑分支。例如对于上面举出的例子,它的模式匹配代码便可能是:

  1. receive  
  2.     {chat, Person, Topic} ->  
  3.         ... % “聊天”逻辑  
  4.     {eat, Restaurant} ->  
  5.         ... % “吃饭”逻辑  
  6.     {work, Person, Job} ->  
  7.         ... % “干活”逻辑  
  8. end 

小写字母开头的标识符为“原子”,可以认为是一个常量,用于标识这个消息用来“干什么”。大写开头的为“绑定”,可以认为是一个变量(虽然不可变),用于标识这个消息“所使用的数据”。如果使用示意图来表示这个消息执行方式,则类似于:

这个消息执行方式 

如果收到的消息是{eat, {mcdonalds, 2}},则会执行“吃饭”逻辑,而执行时Restaurant的值将自动绑定为元组{mcdonalds, 2},而不需要任何转化或赋值操作。Erlang便是这样将一个消息转化为一段逻辑执行的。

【编辑推荐】

  1. Actor模型的本质:究竟是要解决什么问题
  2. 顺畅的使用C# Actor:另一个解决方案
  3. C# Actor的尴尬与F#美丽外表下的遗憾
  4. 看Erlang中Actor模型的执行方式和优劣
  5. Erlang面向分布与并发的编程语言
责任编辑:yangsai 来源: 老赵点滴
相关推荐

2009-07-09 10:02:39

Actor模型Erlang

2018-06-12 15:07:57

IT

2018-06-20 09:09:09

数据存储信息

2020-09-08 10:08:45

分析

2022-08-27 15:27:34

LinuxdockerCompose

2013-11-29 10:08:19

SDN大数据

2019-07-12 12:50:31

数据科学数据转化分析

2023-12-05 14:09:00

数据解析薪酬

2018-05-05 14:53:11

大数据价值项目

2021-04-18 18:42:39

机器学习数据可操作见解

2022-03-08 14:22:01

大数据数据分析技巧

2016-09-06 10:58:31

大数据信息

2012-07-18 09:41:49

jQuery Mobi

2018-05-31 21:57:13

2017-11-14 09:41:18

云计算指标转化

2022-04-14 14:12:19

制造企业数字孪生洞察力

2011-03-23 18:14:13

业务分析优化洞察力

2020-04-22 11:58:34

医疗保健AI人工智能

2015-12-22 11:57:02

数据云计算
点赞
收藏

51CTO技术栈公众号