actor实例

1、actor实例之消息的接收与发送(异步没有返回值)

2、actor实例之消息的接收与发送(同步有返回值)

1、actor实例之消息的接收与发送(异步有返回值)

ActorDemo3.scala
package day05

import scala.actors.{Actor, Future}

/**
  * 用Actor实现同步和异步的消息的发送和消息的接收
  */
class ActorDemo3 extends Actor{
  override def act(): Unit = {
    while (true) {
      // 偏函数
      receive {
        case "start" => println("starting...")
        case AsynMsg(id,msg) => {
          println(s"id:$id,Asyncmsg:$msg")
          Thread.sleep(2000)
          sender ! ReplyMsg(5,"success")
        }
        case SyncMsg(id,msg) => {
          println(s"id:$id,SyncMsg:$msg")
          Thread.sleep(2000)
          sender ! ReplyMsg(5,"success")
        }
      }
    }
  }
}

object ActorDemo3 {
  def main(args: Array[String]): Unit = {
    val actorDemo3: ActorDemo3 = new ActorDemo3
    actorDemo3.start()

    // 异步发送消息,没有返回值
//    actorDemo3 ! AsynMsg(1,"Hi-- Honey")
//    println("没有返回值的异步消息发送完成")
//    // 同步发送消息,线程等待返回值
//    val content: Any = actorDemo3 !? SyncMsg(2,"Hi- lulu")
//    println("有返回值的同步消息发送完成")
//    println(content)

    // 异步发送消息,有返回值,返回类型是Future[Any]
    val reply: Future[Any] = actorDemo3 !! AsynMsg(3,"Hi-ningning")
    Thread.sleep(1000)
    if (reply.isSet) {
      val value = reply.apply()
      println(value)
    }else {
      println("None")
    }

  }
}

case class AsynMsg(id: Int, msg: String)
case class SyncMsg(id: Int, msg:String)
case class ReplyMsg(id: Int, msg: String)
©著作权归作者所有,转载或内容合作请联系作者
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

相关阅读更多精彩内容

  • Spring Cloud为开发人员提供了快速构建分布式系统中一些常见模式的工具(例如配置管理,服务发现,断路器,智...
    卡卡罗2017阅读 136,342评论 19 139
  • 读《快学Scala 》一书的摘要 Scala 运行于JVM之上,拥有海量类库和工具,兼顾函数式编程和面向对象。 在...
    abel_cao阅读 1,360评论 0 8
  • 点击查看原文 Web SDK 开发手册 SDK 概述 网易云信 SDK 为 Web 应用提供一个完善的 IM 系统...
    layjoy阅读 14,235评论 0 15
  • 业务流程是服务的主要用例之一,无论你尝试通过高并发、低延迟业务多服务调用,还是基于各自尝试业务操作、数据读写、服务...
    吕亦行阅读 1,092评论 0 3
  • 本文依照 知识共享许可协议(署名-非商业性使用-禁止演绎) 发布。感谢@严禁扯淡 的修改建议。 2017-2-9:...
    半枚荔枝阅读 5,300评论 0 16

友情链接更多精彩内容