Scala Actor 并发编程

Scala Actor 并发编程

注:Scala Actor 是 scala 2.10.x 版本及以前版本的 Actor。
Scala 在 2.11.x 版本中将 Akka 加入其中,作为其默认的 Actor,老版本的 Actor 已经废弃。

1. Scala Actor概念

Scala 中的 Actor 能够实现并行编程的强大功能,它是基于事件模型的并发机制,Scala是运用消息的发送、接收来实现高并发的。
Actor 可以看作是一个个独立的实体,他们之间是毫无关联的。但是,他们可以通过消息来通信。一个 Actor 收到其他 Actor 的信息后,它可以根据需要作出各种相应。消息的类型可以是任意的,消息的内容也可以是任意的。

2. java 并发编程与 Scala Actor 编程的区别

这里写图片描述

对于 Java,我们都知道它的多线程实现需要对共享资源(变量、对象等)使用 synchronized关键字进行代码块同步、对象锁互斥等等。而且,常常一大块的 try…catch 语句块中加上wait 方法、notify 方法、notifyAll 方法是让人很头疼的。原因就在于 Java 中多数使用的是可变状态的对象资源,对这些资源进行共享来实现多线程编程的话,控制好资源竞争与防止对象状态被意外修改是非常重要的,而对象状态的不变性也是较难以保证的。
与 Java 的基于共享数据和锁的线程模型不同,Scala 的 actor 包则提供了另外一种不共享任何数据、依赖消息传递的模型,从而进行并发编程。

3. Actor 的执行顺序

1、首先调用 start()方法启动 Actor
2、调用 start()方法后其 act()方法会被执行
3、向 Actor 发送消息
4、act 方法执行完成之后,程序会调用 exit 方法

4. 发送消息的方式

这里写图片描述

注意:Future 表示一个异步操作的结果状态,可能还没有实际完成的异步任务的结果
Any 是所有类的超类,Future[Any]的泛型是异步操作结果的类型。

喜欢就点赞评论+关注吧

这里写图片描述

感谢阅读,希望能帮助到大家,谢谢大家的支持!

  • 2
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值