Worker子线程之间的数据交换应用
程序员文章站
2022-07-08 07:59:02
...
一 应用
1、第一条Worker线程负责收集指定范围内的质数。
2、第二条Worker线程负责从指定范围的质数中随机抽取指定数量的质量。
二 代码
1、calPrime.html
<!DOCTYPE html> <html> <head> <meta name="author" content="Yeeku.H.Lee(CrazyIt.org)" /> <meta http-equiv="Content-Type" content="text/html; charset=GBK" /> <title> 计算质数 </title> <style type="text/css"> #show { width: 400px; background-color: #ddd; border-collapse: collapse; } td { border: 1px solid #555; } </style> </head> <body> 起始值:<input type="text" id="start" name="start"/><br/> 结束值:<input type="text" id="end" name="end"/><br/> 个数:<input type="text" id="count" name="count"/><br/> <input type="button" value="计算" onclick="cal();"/> <table id="show"></table> <script type="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; } // 启动第一个Worker线程,该线程用于计算、收集指定范围内的所有质数 var cal = new Worker("worker1.js"); // 定义需要提交给Worker线程的数据 var data = { start : start, end : end }; // 向Worker线程提交数据。 cal.postMessage(JSON.stringify(data)); // 监听onmessage方法,获取worker1.js对应的的Worker线程返回的数据 cal.onmessage = function(event) { // 启动第二个Worker线程,该线程用于随机抽取count个质数 var rand = new Worker("worker2.js"); rand.postMessage({result: event.data , count : count}); // 监听onmessage方法,获取worker2.js对应的的Worker线程返回的数据 rand.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、worker1.js
onmessage = function(event) { // 将数据提取出来。 var data = JSON.parse(event.data); // 取出start参数 var start = data.start; // 取出end参数 var end = data.end; 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线程的宿主脚本中 postMessage(result); }
3、worker2.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); }
三 运行结果
上一篇: 嵌套Worker线程应用
下一篇: 使用WebSocket实现多人实时聊天