嵌套Worker线程应用
来源:互联网 发布:金石期货软件下载 编辑:程序博客网 时间:2024/05/21 09:25
一 应用
1、前台JS脚本先启动一个Worker线程,该Worker线程负责收集该范围内的所有质数。
2、程序把收集到的所有质数再次提交给另外一个Worker线程统计出指定的质数。
二 代码
1、calPrime.html
<!DOCTYPE html><html><head><metaname="author"content="Yeeku.H.Lee(CrazyIt.org)"/><metahttp-equiv="Content-Type"content="text/html; charset=GBK"/><title> 计算质数 </title><styletype="text/css">#show { width:400px; background-color:#ddd; border-collapse: collapse;} td { border:1px solid #555;}</style></head><body> 起始值:<inputtype="text"id="start"name="start"/><br/> 结束值:<inputtype="text"id="end"name="end"/><br/> 个数:<inputtype="text"id="count"name="count"/><br/><inputtype="button"value="计算"onclick="cal();"/><tableid="show"></table><scripttype="text/javascript">var cal =function(){// 得到用户输入的start、end两个值var start = parseInt(document.getElementById("start").value);var end = parseInt(document.getElementById("end").value);var count = parseInt(document.getElementById("count").value);// 如果start大于、等于end,直接结束该函数if(start >= end){return;}var cal =newWorker("worker.js");// 定义需要提交给Worker线程的数据var data ={ start : start, end : end, count : count};// 向Worker线程提交数据。 cal.postMessage(JSON.stringify(data)); cal.onmessage =function(event){var table = document.getElementById("show");// 清空该表格原有的内容 table.innerHTML ="";// 获取Worker线程返回的数据var result = event.data;var nums = result.split(",");// 定义表格总共包含多少列var COLS_NUM =7;for(var i =0; i <=(nums.length -1)/ COLS_NUM ; i++){// 添加表格行var row = table.insertRow(i);// 循环插入7个单元格for(var j =0; j < COLS_NUM && i * COLS_NUM + j < nums.length -1; j++){// 插入单元格、并为单元格设置innerHTML属性 row.insertCell(j).innerHTML = nums[i * COLS_NUM + j]}}}};</script></body></html>
2、worker.js
onmessage =function(event){// 将数据提取出来。var data = JSON.parse(event.data);// 取出start参数var start = data.start;// 取出end参数var end = data.end;// 取出count参数var count = data.count;var result =""; search:for(var n = start ; n <= end ; n++){for(var i =2; i <=Math.sqrt(n); i ++){// 如果除以n的余数为0,开始判断下一个数字。if(n % i ==0){continue search;}}// 搜集找到的质数 result +=(n +",");}// 再次启动Worker线程var sub =newWorker("subworker.js");// 把需要处理的数据传入启动的Worker线程中 sub.postMessage({result: result , count : count}); sub.onmessage =function(event){// 发送消息,将会触发前台JavaScript脚本中// Worker对象的onmessage方法 postMessage(event.data);}}
3、subworker.js
onmessage =function(event){// 将数据提取出来。var data = event.data;// 提取所有质数var primeNums = data.result.split(",")var randResult ="";for(var i =0; i < data.count ; i++){// 计算一个随机索引值var randIndex =Math.floor(Math.random()*(primeNums.length -1));// 随机地"收集"一个质数 randResult +=(primeNums[randIndex]+",");}// 发送消息,将会触发启动它的JavaScript脚本中// 对应Worker对象的onmessage方法 postMessage(randResult);}
三 运行结果
阅读全文
0 0
- 嵌套Worker线程应用
- 与Web Worker线程交换数据应用
- Worker子线程之间的数据交换应用
- 使用Swing Worker线程
- 线程master-worker
- 模板应用--UI线程与worker线程同步 模仿c# invoke
- UI线程与worker线程
- Swing Worker应用举例
- Swing Worker应用举例
- HTML5 web worker应用
- Worker线程使用消息循环
- java线程模型Master-Worker
- <9> go worker线程池
- h5 真正的线程worker
- 关于GUI线程和worker线程
- 关于GUI线程和worker线程
- worker线程建立方法的区别
- Java线程之Worker Thread Pattern
- 判断浏览器在线状态
- window父子窗口之间的调用
- 使用Web Worker创建多线程应用
- 继承
- Android的设计模式-观察者模式
- 嵌套Worker线程应用
- RabbitMQ环境配置,java实例
- JAVA多线程系列--Lock锁-ReentrantLock,ReentrantReadWriteLock应用
- tomcat application server libraries not found
- jquery设置并获取select的相关操作的代码编写
- Android ConstraintLayout 属性列表以及使用
- 与Web Worker线程交换数据应用
- tkinter+matplotlib实现示波器效果,动态显示汽车数据
- python+selenium+phantomjs实现爬虫功能