博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
actor中!(tell)与forward的差别
阅读量:6268 次
发布时间:2019-06-22

本文共 593 字,大约阅读时间需要 1 分钟。

! 的源代码:

def !(message: Any)(implicit sender: ActorRef = Actor.noSender): Unit
tell 的源代码:

final def tell(msg: Any, sender: ActorRef): Unit = this.!(msg)(sender)
forward 的源代码:

def forward(message: Any)(implicit context: ActorContext) = tell(message, context.sender())
通过源代码。我们能够轻而易举的知道 :

!  发送的消息的发送者通过一个隐式转换,把一个ActorRef转换成sender,假设找不到ActorRef的话。那个发送者就是noSender。

forward 发送消息的发送者是当前消息的上一个发送者。

即:

A To B, B To C

假设通过!

的方式发送消息,则C接收到的消息的发送者是B.

假设通过 forward 的方式发送消息。则C接收到的消息的发送者是A.

假设希望 !的方式发送消息的同一时候携带发送者消息,则能够使用  .!(msg)(sender)

假设希望关掉actor,直接shutdown或者使用父亲actor的stop。在actor内部还能够使用context.stop(self)

转载地址:http://htppa.baihongyu.com/

你可能感兴趣的文章
Android 用Handler和Message实现计时效果及其中一些疑问
查看>>
Dos命令删除添加新服务
查看>>
C#.NET常见问题(FAQ)-索引器indexer有什么用
查看>>
hadoop YARN配置参数剖析—MapReduce相关参数
查看>>
Java 正则表达式详细使用
查看>>
【ADO.NET】SqlBulkCopy批量添加DataTable
查看>>
SqlServer--bat批处理执行sql语句1-osql
查看>>
Linux系列教程(十八)——Linux文件系统管理之文件系统常用命令
查看>>
laravel安装初体验
查看>>
用yum查询想安装的软件
查看>>
TIJ -- 吐司BlockingQueue
查看>>
数据库分页查询
查看>>
[编程] C语言枚举类型(Enum)
查看>>
[Javascript] Compose multiple functions for new behavior in JavaScript
查看>>
ASP.NET MVC性能优化(实际项目中)
查看>>
ES6里关于类的拓展(一)
查看>>
零元学Expression Blend 4 - Chapter 46 三分钟快速充电-设定Margin的小撇步
查看>>
Format Conditions按条件显示表格记录
查看>>
RichTextBox指定全部文字显示不同颜色及部分文字高亮颜色显示
查看>>
mysql优化----explain的列分析
查看>>