scala基于事件抽象

import UserStorage._
import akka.actor.{Props, ActorSystem, Stash, Actor}

import scala.sys.Prop

/**
 * Created by zzg on 16-4-22.
 */
case class User2(userName:String,email:String)
object UserStorage{
  trait DBOperation
  object DBOperation{
    case object Create extends DBOperation
    case object Update extends DBOperation
    case object Read extends DBOperation
    case object Delete extends DBOperation
  }
  case object Connect
  case object Disconnect
  case class Operation (dBOperation: DBOperation,user2:Option[User2])
}
class UserStorage extends Actor with Stash {
  def receive = disconnected
  def connected :Actor.Receive = {
    case Disconnect =>
      println("User Storage Disconnect from DB")
      //重新设置
      context.unbecome()    
    case Operation(op,user) =>
      println(s"User Storage receive ${op} to do in user:${user}")
  }
  def disconnected : Actor.Receive = {
    case Connect =>
      println(s"User Storage connect to DB")
      unstashAll()
      //动态切换receive
      context.become(connected)
    case _ =>
      stash()
  }
}
object BecomeHotswap extends App{
  import UserStorage._
  val system = ActorSystem("beconHostwap")
  val userStorage = system.actorOf(Props[UserStorage],"userStorage")
  userStorage ! Operation(DBOperation.Create,Some(User2("Admin", "admin@packt.com")))
  userStorage ! Connect
  userStorage ! Disconnect
  Thread.sleep(100)
  system.shutdown()
}

将事件抽象为对象:DBOperation,通过case基于事件判断不同的事务规则

用context.become,unbecome动态热插拔actor很有用处



转载于:https://my.oschina.net/u/1169079/blog/664603

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

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值