Scala学习--Actor入门

Scala中的Actor类似于Java中的多线程编程,不同的是,Scala的Actor尽可能地避免锁和共享状态,从而避免多线程并发时出现资源争用的情况,进而提升多线程编程的性能。此外,Scala的Actor的这种模型还可以避免死锁等一系列传统的多线程编程的问题。

Actor的创建,启动和消息收发

//Scala提供了Actor trait来更方便地进行actor多线程编程,就Actor trait就类似于Java中的Thread和Runnable一样,是基础的多线程基类和接口,我们只要重写Actor trait的act方法,即可实现自己的线程执行体,与Java中重写run方法类似。
//此外,使用start()方法启动actor;使用符号!,向actor发送消息;actor内部使用receive和模式匹配接收消息。

案例:Actor Hello World

import scala.actors.Actor

class HelloActor extends Actor{
	def act(){
		while(true){
			receive{
				case name:String => println("Hello," + name)
			}
		}
	}
}

val helloActor = new HelloActor
helloActor.start()

helloActor ! "xiaoming"

收发case class类型的消息

//Scala的Actor模型与Java的多线程之间,很大的一个区别就是,Scala Actor天然支持线程之间的精准通信,即一个actor可以给其他actor直接发送消息。
//要给一个actor发送消息,需要使用”actor !消息“的语法。在Scala中,通常建议使用样例类,即case class来进行消息进行发送,然后在actor接收消息后,可以使用Scala强大的模式匹配功能来进行不同消息的处理。

案例:用户注册登录后台接口(向一个Actor发送消息)

case class Login(username:String,password:String)
case class Register(username:String,password:String)

class UserActor extends Actor{
	def act(){
		while(true){
			receive{
				case Login(username,password) => println("login,username is " + username + ",password is " + password)
				case Register(username,password) => println("login,username is " + username + ",password is " + password))
			}
		}
	}
}

val userActor = new UserActor
userActor.start()

userActor ! Register("xiaoming","1234");
userActor ! Login("xiaoming","1234")

Actor之间互相收发消息

//如果两个Actor之间要互相收发消息,那么Scala的建议是,一个actor向另外一个actor发送消息时,同时带上自己的引用,其他actor收到自己的消息时,直接通过发送消息的actor的引用,即可以给他回复消息

案例:打电话

case class Message(content:String,sender:Actor)

class LeoTeliphoneActor extends Actor{
	def act(){
		while(true){
			receive{
				case Message(content,sender) => {
					println("leo telepgone: " + content)
					sender ! "I'm leo,please call me after 10 minutes."
				}
			}
		}
	}
}

class JackTelephoneActor(val leo TelephoneActor:Actor) extends Actor{
	def act(){
		leo TelephoneActor ! Message("Hello,Leo,I'm Jack." ,this)
		receive{
			case response:String => println("Jack telephone: " + response)
		}
	}
}
	

同步消息和Future

//默认情况下,消息都是异步的;但是如果希望发送的消息是同步的,即对方接收后,一定要给自己返回结果,那么可以使用**!?的方式发送消息。即val reply = actor !? message.
//如果要异步发送一个消息,但是在后续要获得消息的返回值,那么可以使用Future。即
!!**语法
val future = actor !! message
val reply = future()

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值