Scala actor的使用
Actor
为什么需要Actor?
Actor的本质即万物皆Actor, Actor之间只有发送消息这一种通信方式。例如,无论是管理员让工作者干活,还是工作者把成果交还给管理员,它们之间也要通过发送消息的方式来传递信息。这么做看似不如直接方法调用来的直接,但是由于大量的消息可以同时执行。同样,消息让Actor之间解耦,消息发出之后执行成功还是失败,需要耗费多少时间,只要没有消息传递回来,这一切都和发送方无关。Actor模型的消息传递形式简化了并行程序的开发,使开发人员无需在共享内存(确切地说,其实是共享“写”)环境中与“锁”、“互斥体”等常用基础元素打交道。
Actor提供了并发程序中与传统的基于锁的结构不同的另一种选择。通过尽可能避免锁和共享状态,Actor使得我们能够更容易地设计出正确,没有死锁或争用状况的程序。
Tip1:
Actor的本质即万物皆Actor, Actor之间只有发送消息这一种通信方式。
Tip2:
避免使用同步调用(!?),它们会阻塞,很有可能引发死锁。
Tip3:
不同的actor可以通过react共享线程。
Tip4:
不同的actor之间不应该共享状态,不要直接调用actor的方法,而是通过消息通信。
1 创建和启动Actor
Tip1:
Actor的消息队列会串行化消息。Actor运行在单个线程中,它会先接受一条消息,然后接收下一条。不用在Actor代码中担心争用状况。
Tip2:
Actor的act方法在start方法被调用时开始执行。如果act方法返回或是由于异常被终止或是actor调用exit方法,都会导致actor终止执行。
Tip3:
如果在receive方法被调用时并没有消息,该调用会阻塞,直到有消息到达。如果发来的消息无法匹配,同样会阻塞,等待下一个消息。
Tip4:
接受消息除了receive和react两种方式还receiveWithin(5000),reactWithin(5000),其中的参数表示在5秒内没收到信息将返回一个Actor.TIMEOUT对象。
结果:
2 与其他Actor通信
Tip1:
Actor可以构造成带有指向一个或更多actor的引用。
Tip2:
Actor可以接受带有指向另一个actor的引用的消息,在请求中提供一个actor引用非常常见。
Tip3:
Actor可以返回消息给发送方。Receive会把sender字段设为当前消息的发送方。
3 共享线程的Actor
Tip1:
尽可能的使用react,使用react的actor可以共享线程。只要消息处理器的工作是执行某个任务,然后退出,你就可以使用react。
Tip2:
每次对react的调用都会抛出异常,进行清栈。
4 同步消息
Tip1:
actor可以发送一个消息并等待回复,用!?操作符即可。
Tip2:
同步消息容易引发死锁,最好避免使用。
5 FUTURE
Tip1:
!!操作符发送的消息会返回一个对象(future),该对象可以稍后处理,也可以发送给其他Actor。
Tip2:
如果立即就想从future接受返回的结果进行处理,就相当于是同步消息(!?)。
6 将多个Actor链接起来
Tip1:
如果你将两个Actor链接在一起,双方都会在另一个终止执行的时候得到通知。
Eg. 监管actor在数个工作actor中分发工作任务,当某个actor挂掉的时候,监管actor应该知道,重新指派工作或是重启该actor。相应的,如果监管actor挂掉,actor也应该知道,以便停止工作。
Tip2:
当一个actor终止的时候,仍保留其内部状态和邮箱(消息队列)。如果要得到这些消息,可以调用该终止actor的restart方法。另外你还可以重新建立链接,因为一个actor终止时其链接会被移除。
Tip3:
当前actor连接到的actor中有一个以非正常(normal)原因退出。当前actor也会终止,退出原因和链接到的那个actor退出原因相同。如果你设置trapExit为true。修改后actor会接收到一个Exit类型的消息,该消息包含了退出原因和正在退出的actor。
运行结果:
Scala actor的使用的更多相关文章
- scala Actor -03
1.对于上一篇讲解的scala的一些补充 val files = Array[String]("a.txt","b.txt","c.txt" ...
- Scala Actor入门
介绍 Scala的Actor类似于Java中的多线程编程.但是不同的是,Scala的Actor提供的模型与多线程有所不同.Scala的Actor尽可能地避免锁和共享状态,从而避免多线程并发时出现资源争 ...
- scala actor编程之对象传递
scala 最吸引人的一点就是actor并发编程了.但是纵观scala官方文档,baidu文档,IBM文档都写的通过字符串传呀传,如果用作actor编程说明当然没有问题.但是在正式开放中,光传字符串就 ...
- scala Actor Akka
推荐博客:过往记忆 https://www.iteblog.com/archives/1154.html akka.io
- Scala 深入浅出实战经典 第68讲:Scala并发编程原生线程Actor、Cass Class下的消息传递和偏函数实战解析
王家林亲授<DT大数据梦工厂>大数据实战视频 Scala 深入浅出实战经典(1-87讲)完整视频.PPT.代码下载: 百度云盘:http://pan.baidu.com/s/1c0noOt ...
- Scala 深入浅出实战经典 第67讲:Scala并发编程匿名Actor、消息传递、偏函数解析
王家林亲授<DT大数据梦工厂>大数据实战视频 Scala 深入浅出实战经典(1-87讲)完整视频.PPT.代码下载:百度云盘:http://pan.baidu.com/s/1c0noOt6 ...
- Scala的Actor模式 & Akka框架
今天学Spark的时候,看到Scala的actor模式是一个加分点.所以搜了一下,看了.主要参考下面两篇文章,还没有实验,有些地方领会的不深刻: http://nxlhero.blog.51cto.c ...
- Scala学习教程笔记三之函数式编程、集合操作、模式匹配、类型参数、隐式转换、Actor、
1:Scala和Java的对比: 1.1:Scala中的函数是Java中完全没有的概念.因为Java是完全面向对象的编程语言,没有任何面向过程编程语言的特性,因此Java中的一等公民是类和对象,而且只 ...
- 大数据入门第二十一天——scala入门(一)并发编程Actor
注:我们现在学的Scala Actor是scala 2.10.x版本及以前版本的Actor. Scala在2.11.x版本中将Akka加入其中,作为其默认的Actor,老版本的Actor已经废弃 一. ...
随机推荐
- Java爬虫原理分析
当我们需要从网络上获取资源的时候,我们一般的做法就是通过浏览器打开某个网站,然后将我们需要的东西下载或者保存下来. 但是,当我们需要大量下载的时候,这个时候通过人工一个个的去点击下载,就显得太没有效率 ...
- [Codeforces 864F]Cities Excursions
Description There are n cities in Berland. Some pairs of them are connected with m directed roads. O ...
- GotoAndPlay
10月3日,在杭州市西湖景区,一只小松鼠不停地接受一道道食物,花生.玉米.饼干,可谓来者不拒,憨态可掬的模样吸引了众多围观者...Description 小松鼠终于吃撑了,她决定逃离这个地方. 我 ...
- poj 3348 Cow 凸包面积
Cows Time Limit: 2000MS Memory Limit: 65536K Total Submissions: 8122 Accepted: 3674 Description ...
- Delphi7通过SendMessage来实现默认打印机的切换
具体代码 procedure SetDefaultPrinter(NewDefPrinter: string); var ResStr: array[0..255] of Char; begin St ...
- Mysql锁机制--概念、分类及基础命令
Mysql 系列文章主页 =============== 1 概念 在 Java 程序中,当多线程并发访问某个资源的时候,如果有非线程安全的操作,那么需要通过加锁来保护之.同理,在 Mysql 中,如 ...
- Eclipse插件安装4种方法
第一种:直接复制法 假设Eclipse的安装目录在C:\eclipse,解压下载的eclipse 插件或者安装eclipse 插件到指定目录AA(如:c:\AA)文件夹,打开AA 文件夹,在AA文件夹 ...
- idea Library XXXXXXXX has broken classes paths
点fix 然后全部 全部按- 删掉 一开始以为会影响很大 后来发现他地址错了都导不进 要是真要用到的时候也没用 还是要maven单独导进来
- linux系统下安装jdk,mysql,tomcat 和redis 和jedis入门案例
Day47笔记Linux+redis入门 Day47 知识讲解:Jedis 1.Linux上jdk,mysql,tomcat安装(看着文档安装) 准备工作: 因为JDK,TOMCAT,MYSQL的 ...
- Linux 查看CPU温度
安装 lm-sensors sudo apt-get install lm-sensors # 安装yes | sudo sensors-detect # 侦测所有感测器 sensors # 查看温度 ...