设为首页收藏本站

LUPA开源社区

 找回密码
 注册
文章 帖子 博客
LUPA开源社区 首页 业界资讯 软件追踪 查看内容

Akka 2.3.8发布,Actor开发模型库

2014-12-16 16:42| 发布者: joejoe0332| 查看: 736| 评论: 0|原作者: oschina|来自: oschina

摘要:   Akka 2.3.8 发布,此版本现已提供下载,暂未有相关说明,改进内容请看commit 列表。  Akka 是一个用 Scala 编写的库,用于简化编写容错的、高可伸缩性的 Java 和 Scala 的 Actor 模型应用。  Actor模型并非 ...

  Akka 2.3.8 发布,此版本现已提供下载,暂未有相关说明,改进内容请看 commit 列表


  Akka 是一个用 Scala 编写的库,用于简化编写容错的、高可伸缩性的 Java 和 Scala 的 Actor 模型应用。


  Actor模型并非什么新鲜事物,它由Carl Hewitt于上世纪70年代早期提出,目的是为了解决分布式编程中一系列的编程问题。其特点如下:


  • 系统中的所有事物都可以扮演一个Actor

  • Actor之间完全独立

  • 在收到消息时Actor所采取的所有动作都是并行的,在一个方法中的动作没有明确的顺序

  • Actor由标识和当前行为描述

  • Actor可能被分成原始(primitive)和非原始(non primitive)类别

  • 非原始Actor有

    • 由一个邮件地址表示的标识

    • 当前行为由一组知识(acquaintances)(实例变量或本地状态)和定义Actor在收到消息时将采取的动作组成

  • 消息传递是非阻塞和异步的,其机制是邮件队列(mail-queue)

  • 所有消息发送都是并行的


  Java代码:

1
2
3
4
5
6
7
8
9
10
11
12
13
// server code
class HelloWorldActor extends UntypedActor {
  public void onReceive(Object msg) {
    getContext().reply(msg + " World");
  }
}
remote().start("localhost"9999).register(
  "hello-service"
   actorOf(HelloWorldActor.class));
// client code
ActorRef actor = remote().actorFor(
  "hello-service""localhost"9999);
Object res = actor.sendRequestReply("Hello");


  Scala 代码:

1
2
3
4
5
6
7
8
9
10
11
12
// server code
class HelloWorldActor extends Actor {
  def receive = 
    case msg => self reply (msg + " World")
  }
}
remote.start("localhost"9999).register(
  "hello-service", actorOf[HelloWorldActor])
// client code
val actor = remote.actorFor(
  "hello-service""localhost"9999)
val result = actor !! "Hello"

酷毙

雷人

鲜花

鸡蛋

漂亮
  • 快毕业了,没工作经验,
    找份工作好难啊?
    赶紧去人才芯片公司磨练吧!!

最新评论

关于LUPA|人才芯片工程|人才招聘|LUPA认证|LUPA教育|LUPA开源社区 ( 浙B2-20090187 浙公网安备 33010602006705号   

返回顶部