一 应用
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);
}
三 运行结果

本文介绍了一个使用HTML和JavaScript的Web应用程序,该程序利用Web Worker技术并行计算指定范围内的质数,并从中随机选择一定数量的质数进行展示。
6483

被折叠的 条评论
为什么被折叠?



