Scala-Unit7-Scala并发编程模型AKKA
一、Akka简介
Akka时spark的底层通信框架,Hadoop的底层通信框架时rpc。
并发的程序编写很难,但是Akka解决了spark的这个问题。
Akka构建在JVM平台上,是一种高并发、分布式、并且容错的应用工具包;
Akka使用Scala语言编写,同时它提供了Scala和Java的开发接口,Akka可以开发一些高并发的程序。
二、Akka的Acor模型
A卡卡处理并发的方法基于actor模型,在基于actor的系统中,所有事物都是actor(类似于Java的万物皆对象);
actor是一个并发模型设计的架构,而面对对象不属于结构,它是一门思想;

如上如,actor与actor直接只能通过消息通信,
当一个actor给另一个actor发送消息时,只需要将消息发送给actor对应的代理(emailBox)即可,
而actor怎么处理消息是我们自己定义的。
三、Akka特点
1.对并发模型进行了更高的抽象;
2.它是异步、非阻塞、高性能的事件驱动编程模型;
3.它是一个轻量级的时间编程模型(1GB内存可以容纳百万级别的Actor)
4.actor简化了并发编程,提高了程序的性能
四、Akka编程
1.需求1:我对自己发送消息,并处理消息
//创建CallMe类继承Actor,它包含了对消息处理的业务逻辑
class CallMe extends Actor{
//重写recevie方法,负责接收和处理消息
override def receive: Receive = {
case "Hunter is cool" => println("You are Right")
case "Hunter is ugly" => println("You are wrong")
case "stop" => {
//关闭代理ActorRef
context.stop(self)
//关闭ActorSystem
context.system.terminate()
}
}
} object CallMe {
//1.创建ActorSystem对象
private val acFactory = ActorSystem("AcFactory")
//2.调用ActorSystem对象的ActorOf方法,创建代理callRef
private val callRef = acFactory.actorOf(Props[CallMe],"CallMe") def main(args: Array[String]): Unit = {
//3.发送消息, !代表发送的意思
callRef ! "Hunter is cool"
callRef ! "Hunter is ugly"
callRef ! "stop"
}
}
2.需求2:男孩和女孩的对话模拟
class BoyActor(val b:ActorRef) extends Actor{
override def receive: Receive = {
case "你好,mm" => {
b ! "你好,mm"
}
case "你好,gg" => {
println("你好,gg")
b ! "我能约你吃饭么?"
}
case "叔叔,我们不约!" =>{
println("叔叔,我们不约!")
context.stop(self)
context.system.terminate()
}
}
}
class GirlActor(val g:ActorRef) extends Actor{
override def receive: Receive = {
case "你好,mm" =>{
println("你好,mm")
g ! "你好,gg"
}
case "我能约你吃饭么?" =>{
println("我能约你吃饭么?")
g ! "叔叔,我们不约!"
}
}
}
object WeChat {
private val weChat = ActorSystem("WeChat")
private val boyRef: ActorRef = weChat.actorOf(Props(new BoyActor(girlRef)),"Boy")
private val girlRef: ActorRef = weChat.actorOf(Props(new GirlActor(boyRef)),"Girl")
def main(args: Array[String]): Unit = {
boyRef ! "你好,mm"
}
}
运行结果:

Scala-Unit7-Scala并发编程模型AKKA的更多相关文章
- Scala进阶之路-并发编程模型Akka入门篇
Scala进阶之路-并发编程模型Akka入门篇 作者:尹正杰 版权声明:原创作品,谢绝转载!否则将追究法律责任. 一.Akka Actor介绍 1>.Akka介绍 写并发程序很难.程序员不得不处 ...
- Scala并发编程模型AKKA
一.并发编程模型AKKA Spark使用底层通信框架AKKA 分布式 master worker hadoop使用的是rpc 1)akka简介 写并发程序很难,AKKA解决spark这个问题. akk ...
- 15. Scala并发编程模型Akka
15.1 Akka介绍 1) Akka是Java虚拟机JVM平台上构建高并发.分布式和容错应用的工具包和运行时,可以理解成Akka是编写并发程序的框架 2) Akka用Scala语言写成,同时提供了S ...
- 用scala的actor并发编程写一个单机版的WorldCount
前言:最近一段时间比较忙,也是比较懒了吧,好长时间没写博客了,新的一年到来,给自己一个小目标,博客坚持写下去,分享一下这历程!废话不多说,开始正题咯(希望大家喜欢!) 首先这算是一个scala程序的入 ...
- 4、Java并发性和多线程-并发编程模型
以下内容转自http://ifeve.com/%E5%B9%B6%E5%8F%91%E7%BC%96%E7%A8%8B%E6%A8%A1%E5%9E%8B/: 并发系统可以采用多种并发编程模型来实现. ...
- java 多线程——并发编程模型 学习笔记
并发编程模型 ...
- Java并发编程的艺术读书笔记(2)-并发编程模型
title: Java并发编程的艺术读书笔记(2)-并发编程模型 date: 2017-05-05 23:37:20 tags: ['多线程','并发'] categories: 读书笔记 --- 1 ...
- Reactor 模型(一)基本并发编程模型
Reactor 模型(一)基本并发编程模型 Netty 系列目录 (https://www.cnblogs.com/binarylei/p/10117436.html) 在讲解 Reactor 线程模 ...
- Scala 并行和并发编程-Futures 和 Promises【翻译】
官网地址 本文内容 简介 Futures 阻塞 异常 Promises 工具 最近看了<七周七语言:理解多种编程泛型>,介绍了七种语言(四种编程范型)的主要特性:基本语法,集合,并行/并发 ...
随机推荐
- 详解 HTTPS、TLS、SSL、HTTP区别和关系
一.什么是HTTPS.TLS.SSL HTTP也称作HTTP over TLS.TLS的前身是SSL,TLS 1.0通常被标示为SSL 3.1,TLS 1.1为SSL 3.2,TLS 1.2为SSL ...
- 巧用&&和|| 让逻辑代码更简洁,逼格看起来更高一点(玩笑脸)
通常当我们有一个需求 需要用到很多if else 进行条件筛选,例如: let level = 0; if(score > 12){ level = 4; } else if(score > ...
- elementui上传图片到七牛云服务器
注册七牛云 首先,注册七牛云,并且完成实名认证,完成后会在个人中心->秘钥管理中看到两个秘钥AccessKey/SecretKey 创建存储空间(必须要实名认证) 生成上传凭证 为了实现上传,我 ...
- python面试30-40题
1.简述python引用计数机制 python垃圾回收主要以引用计数为主,标记-清除和分代清除为辅的机制,其中标记-清除和分代回收主要是为了处理循环引用的难题. 引用计数算法 当有1个变量保存了对 ...
- usrp使用
首先打开linux 输入uhd_find_divice gqrx
- java Swing组件和事件处理
1.常见的容器 JComponent是 Container 的子类,中间容器必须添加到底层容器中才能够发挥作用, JPanel 面板 :使用jPanel 创建一个面板,再通过添加组件到该面板上面,JP ...
- tensorflow(1) 基础: 神经网络基本框架
1.tensorflow 的计算得到的是计算图graph import tensorflow as tf a=tf.constant([1.0,2.0]) b=tf.constant([3.0,4.0 ...
- 动手动脑——JAVA语法基础
EnumTest.java public class EnumTest { public static void main(String[] args) { Size s=Size.SMALL; Si ...
- Python中的构造方法
在Java等语言中都有构造方法[进行对象的创建及初始化]这个东东,示例代码如下: public class Student { //成员变量 private String name; private ...
- Java接口自动化测试之集成MyBatis和MySQL (五)
pom.xml新增dependency <dependency> <groupId>org.mybatis</groupId> <artifactId> ...