1.对于上一篇讲解的scala的一些补充

    val files = Array[String]("a.txt","b.txt","c.txt")

    for(f <- files){xxxx}

  目标一:熟悉Scala Actor并发编程

  目标二:为学习Akka做准备

    注:我们现在学的Scala Actor是scala 2.10.x版本及以前版本的Actor。

    Scala在2.11.x版本中将Akka加入其中,作为其默认的Actor,

    老版本的Actor已经废弃

   2.概念

    Scala中的Actor能够实现并行编程的强大功能,它是基于事件模型的

    并发机制,

    Scala是运用消息(message)的发送、接收来实现多线程的。

    使用Scala能够更容易地实现多线程应用的开发

   3.Actor方法执行顺序

    1.首先调用start()方法执行Actor

    2.调用start()方法后其act()方法会被执行

    3.向Actor发送消息

   4.wordCount的Actor的计算方法,虽然现在不用,但是思路还是有用的

    

package main.cn.wj.test
import scala.actors.{Actor, Future}
import scala.collection.immutable.HashSet
import scala.io.Source
import scala.collection.mutable.ListBuffer
/**
* Created by WJ on 2016/12/22.
*/ class Task extends Actor{
override def act(): Unit = {
loop{
react{
case SubmitTask(filename) =>{
val result = Source.fromFile(filename).getLines().flatMap(_.split(" ")).map((_,1)).toList.groupBy(_._1).mapValues(_.size)
sender ! ResultTask(result)
}
case StopTask =>{
exit()
}
}
}
}
} case class SubmitTask(filename:String) case class ResultTask (result:Map[String,Int]) case object StopTask object ActorWordCount {
def main(args: Array[String]): Unit = {
var replySet = new HashSet[Future[Any]]()
val resultList = new ListBuffer[ResultTask]
val files = Array[String]("E://Test/words.log", "E://Test/words.txt")
for (f <- files) {
val actor = new Task
val reply = actor.start() !! SubmitTask(f) //<reply 等同于Future>
replySet += reply
}
while(replySet.size > 0 ){
val toCompute = replySet.filter(_.isSet)
for(f <- toCompute) {
val result = f.apply().asInstanceOf[ResultTask]
resultList += result
replySet -= f
}
Thread.sleep(100)
} // reduce功能 ,汇总
//List
val fr = resultList.flatMap(_.result).groupBy((_._1)).mapValues(_.foldLeft(0)(_+_._2))
println(fr)
}
}

  5.看了上面的关于多线程相关的知识点,看看我们的线程池的代码

  

package main.cn.wj.test

import java.util.concurrent.{Executor, Executors}

/**
* Created by WJ on 2016/12/22.
*/
object ThreadDemo {
def main(args: Array[String]): Unit = {
val pool = Executors.newFixedThreadPool(5);
for (i <- 1 to 10){
pool.execute(new Runnable {
override def run(): Unit = {
println(Thread.currentThread().getName)
Thread.sleep(1000)
}
})
}
}
}

scala Actor -03的更多相关文章

  1. Scala Actor入门

    介绍 Scala的Actor类似于Java中的多线程编程.但是不同的是,Scala的Actor提供的模型与多线程有所不同.Scala的Actor尽可能地避免锁和共享状态,从而避免多线程并发时出现资源争 ...

  2. scala actor编程之对象传递

    scala 最吸引人的一点就是actor并发编程了.但是纵观scala官方文档,baidu文档,IBM文档都写的通过字符串传呀传,如果用作actor编程说明当然没有问题.但是在正式开放中,光传字符串就 ...

  3. 大数据系列修炼-Scala课程03

    前言 今天上班看了很多关于前端js,jQuery.bootstrap.js以及springMVC看得迷迷糊糊的,毕竟以前很少去学习前端的技术,所有看得有点困,还好看得比较多,回家后也开始学习关于Sca ...

  4. Scala actor的使用

    Actor 为什么需要Actor? Actor的本质即万物皆Actor, Actor之间只有发送消息这一种通信方式.例如,无论是管理员让工作者干活,还是工作者把成果交还给管理员,它们之间也要通过发送消 ...

  5. scala Actor Akka

    推荐博客:过往记忆 https://www.iteblog.com/archives/1154.html akka.io

  6. Scala面向对象03

  7. Scala语法03 - 函数

  8. Scala 深入浅出实战经典 第68讲:Scala并发编程原生线程Actor、Cass Class下的消息传递和偏函数实战解析

    王家林亲授<DT大数据梦工厂>大数据实战视频 Scala 深入浅出实战经典(1-87讲)完整视频.PPT.代码下载: 百度云盘:http://pan.baidu.com/s/1c0noOt ...

  9. Scala 深入浅出实战经典 第67讲:Scala并发编程匿名Actor、消息传递、偏函数解析

    王家林亲授<DT大数据梦工厂>大数据实战视频 Scala 深入浅出实战经典(1-87讲)完整视频.PPT.代码下载:百度云盘:http://pan.baidu.com/s/1c0noOt6 ...

随机推荐

  1. ATL

    Normal COM.cpp #include "resource.h" // 主符号 #include "ATLCOM_i.h" #include " ...

  2. js获取农历日期【转】

    var CalendarData=new Array(100); var madd=new Array(12); var tgString="甲乙丙丁戊己庚辛壬癸"; var dz ...

  3. python 生成随机图片验证码

    1.安装pillow模块 pip install pillow (1)创建图片 from PIL import Image #定义使用Image类实例化一个长为400px,宽为400px,基于RGB的 ...

  4. 《spring技术内幕》读书笔记(1)——什么是POJO模式

    今天在看<spring技术内幕>,第一章中多次提到了使用POJO来完成开发,就百度了一下,在此保留 1.     什么是POJO POJO的名称有多种,pure old java obje ...

  5. bootstrap-table之通用方法( 时间控件,导出,动态下拉框, 表单验证 ,选中与获取信息)

    1.bootstrap-table 单击单行选中 $('#gzrwTable').on('click-row.bs.table', function(e, row, $element) { $('.s ...

  6. 06、部署Spark程序到集群上运行

    06.部署Spark程序到集群上运行 6.1 修改程序代码 修改文件加载路径 在spark集群上执行程序时,如果加载文件需要确保路径是所有节点能否访问到的路径,因此通常是hdfs路径地址.所以需要修改 ...

  7. zendstudio 汉化

    http://archive.eclipse.org/technology/babel/index.php http://www.eclipse.org/babel/downloads.php 注册码 ...

  8. DataGrid 样式

    <SolidColorBrush x:Key="OutsideFontColor" Color="#FF000000" /> <LinearG ...

  9. MySQL入门很简单: 10 mysql运算符

    1. 算术运算符 例子: 将t1表中字段a的值进行加法,减法和乘法 2. 比较运算符 注:LIKE经常和通配符"_"和"%"一起使用,"_" ...

  10. Selenium入门19 捕获异常

    脚本出现异常时会中断执行,想要继续执行就要做异常处理: 1 try ... except .... else   遇到异常显示异常信息: 没有异常继续执行else后面的脚本 2 try ... exc ...