日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

Akka并发编程——第七节:Actor模型(六)

發布時間:2024/1/23 编程问答 42 豆豆
生活随笔 收集整理的這篇文章主要介紹了 Akka并发编程——第七节:Actor模型(六) 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

主要內容:
1. Typed Actor定義
2. Typed Actor創建
3. 消息發送

1. Typed Actor定義

Akka中的Typed Actor是Active Objects設計模式的實現,Active Objects模式將方法的執行和方法的調用進行解耦合,從而為程序引入并發性。Typed Actor由公用的接口和對應實現兩部分構成,其后面深層次的實現使用的是代理模式,即通過使用JDK中的動態代理來實現,在調用接口的方法時自動分發到實現接口的對象上。Typed Actor的定義[ ]如下所示。

trait Squarer {//fire-and-forget消息def squareDontCare(i: Int): Unit//非阻塞send-request-reply消息def square(i: Int): Future[Int]//阻塞式的send-request-reply消息def squareNowPlease(i: Int): Option[Int]//阻塞式的send-request-reply消息def squareNow(i: Int): Int}class SquarerImpl(val name: String) extends Squarer {def this() = this("SquarerImpl")def squareDontCare(i: Int): Unit = i * idef square(i: Int): Future[Int] = Promise.successful(i * i).futuredef squareNowPlease(i: Int): Option[Int] = Some(i * i)def squareNow(i: Int): Int = i * i}

trait Squarer中定義了4個方法:
(1)def squareDontCare(i: Int): Unit方法:返回值類型為Unit,它類似于Untyped Actor中的fire-and-forget消息發送模型,即!和tell方法調用。
(2)def square(i: Int): Future[Int]:返回值類型為Future[Int],它類似于Untyped Actor中的send-request-reply消息發送模型,即?和ask方法調用,此種調用是非阻塞的。
(3)def squareNowPlease(i: Int): Option[Int]:返回值類型為Option[Int](Option類可以是Scala.Option[_]也可以是akka.japi.Option

2. 創建Typed Actor

通過下列代碼創建Typed Actor實例。

//直接通過默認的構造函數創建Typed Actor val mySquarer: Squarer =TypedActor(system).typedActorOf(TypedProps[SquarerImpl]()) //直接通過默認的構造函數創建Typed Actor并指定Typed Actor名稱 val mySquarer: Squarer =TypedActor(system).typedActorOf(TypedProps[SquarerImpl](),"mySquarer") //通過非默認的構造函數創建Typed Actor并指定Typed Actor名稱 val otherSquarer: Squarer = TypedActor(system).typedActorOf(TypedProps(classOf[Squarer],new SquarerImpl("SquarerImpl")), "otherSquarer")

上面代碼演示的是使用構造函數和非默認構造函數創建Typed Actor,其中Squarer為代理的類型,SquarerImpl為具體實現的類型。

3. 消息發送

//fire-forget消息發送mySquarer.squareDontCare(10)//send-request-reply消息發送val oSquare = mySquarer.squareNowPlease(10)val iSquare = mySquarer.squareNow(10)//Request-reply-with-future 消息發送val fSquare = mySquarer.square(10)val result = Await.result(fSquare, 5 second)

代碼mySquarer.squareDontCare(10)是單向消息發送,方法將在另外一個線程上異步地執行;val oSquare = mySquarer.squareNowPlease(10)、val iSquare = mySquarer.squareNow(10)為Request-reply消息發送,在特定時間內以阻塞的方式執行,對于.squareNowPlease(10)方法如果在對應時間內沒有返回結果則返回值為None,否則返回值為Option[Int]類型,對于squareNow(10)方法如果在對應時間內無返回值則會拋出異常Java.util.concurrent.TimeoutException,否則返回Int類型值;val fSquare = mySquarer.square(10)為Request-reply-with-future式的消息發送,以非阻塞的方式執行,可以通過val result = Await.result(fSquare, 5 second)獲取執行結果。完整代碼如下所示。

/** Typed Actor*/ object Example_01 extends App {import akka.event.Loggingimport scala.concurrent.{ Promise, Future }import akka.actor.{ TypedActor, TypedProps }import scala.concurrent.duration._trait Squarer {//fire-and-forget消息def squareDontCare(i: Int): Unit//非阻塞send-request-reply消息def square(i: Int): Future[Int]//阻塞式的send-request-reply消息def squareNowPlease(i: Int): Option[Int]//阻塞式的send-request-reply消息def squareNow(i: Int): Int}class SquarerImpl(val name: String) extends Squarer {def this() = this("SquarerImpl")def squareDontCare(i: Int): Unit = i * idef square(i: Int): Future[Int] = Promise.successful(i * i).futuredef squareNowPlease(i: Int): Option[Int] = Some(i * i)def squareNow(i: Int): Int = i * i}val system = ActorSystem("TypedActorSystem")val log = Logging(system, this.getClass)//使用默認構造函數創建Typed Actorval mySquarer: Squarer =TypedActor(system).typedActorOf(TypedProps[SquarerImpl](),"mySquarer")//使用非默認構造函數創建Typed Actorval otherSquarer: Squarer =TypedActor(system).typedActorOf(TypedProps(classOf[Squarer],new SquarerImpl("SquarerImpl")), "otherSquarer")//fire-forget消息發送mySquarer.squareDontCare(10)//send-request-reply消息發送val oSquare = mySquarer.squareNowPlease(10)log.info("oSquare="+oSquare)val iSquare = mySquarer.squareNow(10)log.info("iSquare="+iSquare)//Request-reply-with-future 消息發送val fSquare = mySquarer.square(10)val result = Await.result(fSquare, 5 second)log.info("fSquare="+result)system.shutdown() }

代碼運行結果如下:
[INFO] [03/21/2016 21:15:50.592] [main] [Example12_9(akka://TypedActorSystem)]oSquare=Some(100)[INFO][03/21/201621:15:50.649][main][Example129(akka://TypedActorSystem)] iSquare=100
[INFO] [03/21/2016 21:15:50.649] [main] [Example12_9$(akka://TypedActorSystem)] fSquare=100

創作挑戰賽新人創作獎勵來咯,堅持創作打卡瓜分現金大獎

總結

以上是生活随笔為你收集整理的Akka并发编程——第七节:Actor模型(六)的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。

主站蜘蛛池模板: 红桃视频黄色 | 国产精品又黄又爽又色无遮挡 | 嫩草视频免费观看 | 暖暖成人免费视频 | 性高潮久久久久 | 欧美激情久久久 | 日韩精品一区二区三区久久 | 日韩精品一区二区三 | 宇都宫紫苑在线播放 | 香蕉精品视频在线观看 | www.看毛片| 久久午夜影视 | 在线一区二区三区视频 | 成人123| 午夜国产福利在线 | 男人舔女人下部高潮全视频 | 国模杨依粉嫩蝴蝶150p | 久久国产经典视频 | 欧美国产不卡 | 午夜国产精品视频 | 久久77777 | 日本视频在线播放 | 女人天堂网| 精品免费在线视频 | 精品一区二区久久久久久按摩 | 夜夜骑夜夜 | 无套内谢的新婚少妇国语播放 | 久热中文字幕在线 | 91精品国产一区二区三区 | 91视频爱爱| 午夜影院0606 | 美女扒开尿口给男人看 | 国产乱国产乱300精品 | 一个人在线免费观看www | 久久久久久久久久久丰满 | 全黄一级片 | 日韩av中文字幕在线免费观看 | 宅男视频在线免费观看 | 日韩亚洲精品视频 | 久久国产成人精品国产成人亚洲 | 伊人久久亚洲 | 久操精品视频 | 久久99精品久久久久久噜噜 | 男操女视频网站 | 国产aⅴ精品一区二区果冻 台湾性生生活1 | 国产日韩一区二区三免费高清 | 国产亚洲精品久久777777 | 国产又粗又硬又黄的视频 | 人妻互换免费中文字幕 | 销魂美女一区二区 | 男女污污视频在线观看 | 一区二区xxx | 动漫av在线免费观看 | 亚洲免费影院 | www.av麻豆| 久久久久亚洲国产 | 丨国产丨调教丨91丨 | 色呦呦在线观看视频 | 中文字幕 国产 | 久久国产二区 | 欧美成人国产精品高潮 | 天天爱天天射 | 中文字幕在线播放第一页 | 国产精品成人一区 | 一区二区三区四区精品 | 人人草人 | 久久综合一区二区三区 | 中文一二区 | 人妖一区二区三区 | 精品一区电影国产 | 超碰av免费 | 一区=区三区乱码 | 视频一区 中文字幕 | 青青草成人免费在线视频 | 波多野结衣视频免费观看 | 台湾swag在线播放 | 超碰人人人人人人 | 日日夜夜噜 | 久青草视频在线观看 | 国产女优在线播放 | 一区二区不卡视频在线观看 | 国产欧美日韩精品在线观看 | 亚洲一级网站 | 一区二区三区欧美视频 | 东京热加勒比无码少妇 | 亚洲乱码国产乱码精品精 | 久久精品视频免费播放 | 日韩精品免费一区二区夜夜嗨 | 男人插女人下面视频 | 一二区在线视频 | 成人手机在线视频 | 亚洲国产黄色 | 瑟瑟视频免费看 | 妺妺窝人体色www在线下载 | 亚洲天堂777 | 国产成人精品一区二区三区无码熬 | 国产福利合集 | 日日撸夜夜撸 | 久久婷婷五月综合色吧 |