Akka入门学习

news/2024/11/7 9:33:30/

akka基础学习

Akka是用Scala创建的,但由于Scala和Java一样,都是java虚拟机上的语言,本质上说,两者并没有什么不同,因此,我们也可以在Java中使用Akka。我们知道,写出一个正确的、高性能并且可扩展的并发程序是相当困难的,那么是否有一个好的框架可以帮助我们轻松构建这么一个应用呢?这就是Akka。

Akka的好处

  • 首先,Akka提供了一种名为Actor的并发模型,其粒度比线程小,这意味着可以在系统中启用大量的Acotr。
  • 其次,Akka中提供了一套容错机制,允许在Acotr出现异常时,进行一些恢复或者重置操作。
  • 再次,通过Akka不仅可以在单机上构建高并发程序,也可以在网络中构建分布式程序,并提供位置透明的Actor定位服务。

在这里插入图片描述

新并发模型:Actor

对于并发程序来说,线程始终是并发程序的基本执行单元。但在Akka中,我们可以完全忘记线程了。当使用Akka时,我们就有一个全新的执行单元----Actor。
在Actor模型中,我们失去了对象的方法调用,我们并不能通过调用Actor对象的某一个方法来告诉Actor你需要做什么,而是给Actor发送一条消息。当一个Actor收到消息后,它有可能会根据消息的内容做出某些行为,包括更改自身状态。在这种情况下,这个状态的更改是Actor自己进行的,并不是由外界被迫进行的。

Akka之Hello World

第一个Actor

public class Greeter extends UntypedAbstractActor {public static enum Msg{GREET,DONE;//定义了消息类型}@Overridepublic void onReceive(Object message) throws Throwable {if(message==Msg.GREET){System.out.println("Hello World");getSender().tell(Msg.DONE,getSelf());}else{unhandled(message);}}
}

与Greeter交流的另一个Actor

public class HelloWorld extends UntypedAbstractActor {ActorRef greeter;@Overridepublic void preStart() throws Exception {//回调方法greeter=getContext().actorOf(Props.create(Greeter.class),"greeter");//创建了Greeter的实例System.out.println("Greeter Actor Path:"+greeter.path());greeter.tell(Greeter.Msg.GREET,getSelf());//向Greeter发送消息}@Overridepublic void onReceive(Object message) throws Throwable {//消息处理函数if(message==Greeter.Msg.DONE){greeter.tell(Greeter.Msg.GREET,getSelf()); //向Greeter发送消息getContext().stop(getSelf());//停止}else {unhandled(message);}}public static void main(String[] args) {ActorSystem system=ActorSystem.create("Hello");//创建ActorSystem,用来维护和管理Actor的系统ActorRef a=system.actorOf(Props.create(HelloWorld.class),"helloWorld");System.out.println("HelloWorld Acotr Paht:"+a.path());}
}

打印结果
在这里插入图片描述

当系统内有多个Actor存在时,Akka会自动在线程池中选择线程来执行我们的Actor。因此,多个不同的Acotr有可能会被同一个线程执行,同时,一个Actor也有可能被不同的线程执行。因此,需要注意的地方是:不要再一个Actor中执行耗时的代码,这样可能会导致其它Actor的调度出现问题。


http://www.ppmy.cn/news/882696.html

相关文章

【OI】好用的网站

好用的网站 一些好用的网站。 图床 {\color{DarkBlue}\text{图床}} 图床 几何 {\color{DarkBlue}\text{几何}} 几何 图论 {\color{DarkBlue}\text{图论}} 图论 函数 {\color{DarkBlue}\text{函数}} 函数 找规律 {\color{DarkBlue}\text{找规律}} 找规律 矩阵运算 {\color{…

Orika 使用方法

加入依赖&#xff1a; <dependency><groupId>ma.glasnost.orika</groupId><artifactId>orika-core</artifactId><version>x.y.z</version> </dependency>/*** 测试属性复制功能&#xff1a;* - [x] 同名属性* - [x] 非同名属…

Kaldi入门:yesno项目

这个学期选了一门自然语言处理课&#xff0c;结果这门课主要的研究课题是自动语音识别&#xff08;ASR&#xff09;。既然入了这个坑。就先好好了解一下如何做ASR吧。 老师Tom Ko要求使用Kaldi这个工具来做ASR。课上到一半才知道Kaldi中有几千行的脚本代码是老师提交的。好吧&a…

okio

随着越来越多的应用使用OKHttp来进行网络访问&#xff0c;我们有必要去深入研究OKHTTP的基石&#xff0c;一套更加轻巧方便高效的IO库okio. OKIO的优点 有同学或会问&#xff0c;目前Java的IO已经非常成熟了&#xff0c;为什么还要使用新的IO库呢&#xff1f;笔者认为&#xff…

Okio简介

一、简介 是由square公司开发的用于IO读取。补充了Java.io和java.nio的不足&#xff0c;以便能够更加方便&#xff0c;快速的访问、存储和处理数据。内部的读写操作是在内存中进行的。 二、使用 Okio的使用非常方便&#xff0c;相比java.io库它简化了很多繁杂的东西。这其中…

如何使用Erika OS配置工具 ----初见Erika

致自己&#xff1a;与其感慨路难行&#xff0c;不如马上出发&#xff01; 一、 什么是Erika OS Erika OS是一个基于OSEK标准的开源操作系统.采用Oil (OSEK Implementation Language)文件描述OS配置&#xff0c;具有基于Eclipse工具的可配置 &#xff0c;易裁剪的OS。 官网地址…

Okio的使用简介

Okio的使用简介 . 简介 Okio 是由square公司开发的用于IO读取。补充了Java.io和java.nio的不足&#xff0c;以便能够更加方便&#xff0c;快速的访问、存储和处理数据。内部的读写操作是在内存中进行的。是OkHttp的底层IO库。 . Okio的核心类 ByteStrings: 是不可变的字节…

Ichimoku Kinko Hyo

Ichimoku kinko hyo&#xff08;云图指标&#xff09; 云图、或一目均衡表指标&#xff08;Ichimoku kinko hyo&#xff09;&#xff0c;简称IKH&#xff0c;此指标是由笔名为Ichimoku Sanjin的日本记者在1930年代发明的&#xff0c;它是显示市场趋势&#xff0c;趋势的强弱&am…