`
cakin24
  • 浏览: 1396108 次
  • 性别: Icon_minigender_1
  • 来自: 西安
社区版块
存档分类
最新评论

嵌套Worker线程应用

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

 
  • 大小: 39.4 KB
  • 大小: 21.2 KB
1
1
分享到:
评论

相关推荐

    软件工程中的多线程编程实践.pptx

    - 避免嵌套锁定。 - **处理资源竞争**: - 采用细粒度锁。 - 使用不可变对象。 - **提高性能**: - 减少不必要的同步操作。 - 使用线程局部变量。 **关键实践** - **线程池**:管理线程的创建和销毁,提高...

    JavaScript多线程编程简介.txt

    本文将详细介绍如何在JavaScript中实现多线程编程,包括基本概念、实现机制以及一些典型的应用场景。 #### 二、JavaScript中的多线程需求与挑战 1. **需求背景**:随着Web应用的复杂度不断提升,前端开发中常常...

    wasm-mt:用于Rust和WebAssembly的多线程库

    wasm-mt帮助您创建和执行基于Web Worker的线程。 您可以简单地使用Rust闭包对线程进行编程,并使用async/await对其进行编排。例子wasm-mt-pool wasm-mt基于wasm-mt线程池库。 [| ] 您可以在浏览器中运行以下所有...

    c#线程池应用

    ### C#线程池应用详解 #### 一、引言 ...通过合理地使用线程池,开发者可以构建出更加健壮和高效的多线程应用。了解线程池的基本原理和应用场景,有助于开发者更好地利用这项技术来优化应用的性能。

    Android应用源码优化大师源代码.zip

    - **UI渲染**:减少主线程负载,避免在主线程进行耗时操作,使用AsyncTask或Worker线程处理后台任务。 - **布局优化**:简化XML布局,避免深嵌套,使用merge标签,减少视图复用。 - **资源优化**:使用Nine-Patch...

    疯狂HTML 5+CSS 3+JavaScript讲义(第2版)+源代码

    18.3 Worker线程嵌套 594 18.4 使用SharedWorker创建共享线程 597 18.5 Promise 603 18.6 本章小结 611 第19章 客户端通信 612 19.1 跨文档消息传递 613 19.2 使用WebSocket与服务器通信 621 19.3 使用...

    Android代码-Android-performance-optimization

    - 使用AsyncTask或Worker线程处理耗时操作,避免阻塞主线程。 2. 内存管理优化: - 避免内存泄漏:尤其是像Handler这样的长期运行的对象,可能导致Activity无法被正确回收。 - 使用弱引用:当对象不再使用时,...

    鸿蒙高级开发者认证题库

    - Worker线程用于后台任务处理,其最大同时激活数量限制为8个。 **26. 端云一体化实现方式** - **正确选项:** 通过工程模板实现端云一体化。 - 工程模板提供了快速构建端云一体化项目的便捷方式。 **27. @State...

    Android项目.rar

    1. 性能优化:包括UI流畅度(减少不必要的布局嵌套,使用AsyncTask或Worker线程处理耗时操作),内存管理(避免内存泄漏,合理使用软引用和弱引用),以及数据库查询优化。 2. 资源优化:减小APK大小(使用ProGuard...

    Lua在Nginx中的应用

    这些处理可以在Nginx的多个阶段进行,比如init_by_lua(在worker进程初始化时)、set_by_lua(在响应头处理前)、rewrite_by_lua(在重写阶段)、access_by_lua(在访问控制阶段)和content_by_lua(在内容生成阶段...

    C# 小实例 关于进度条的使用

    对于更复杂的进度显示,例如分段进度条,可以通过嵌套多个进度条或者自定义控件实现。在WPF中,利用数据绑定和模板可以轻松创建这种效果。 总的来说,C#中的进度条是一个直观且实用的控件,通过合理地配置和使用,...

    Angular Source Code Tour [pdf]

    这使得开发者可以在后台线程上运行 Angular 应用程序,从而提高性能和响应性。 #### 十一、@angular/platform-webworker-dynamic **@angular/platform-webworker-dynamic** 为 Web Worker 环境提供动态加载模块的...

    android 城市选择

    1. **AsyncTask/Worker线程**: 网络请求应在后台线程进行,防止阻塞主线程,使用AsyncTask或WorkManager。 2. **Adapter适配器**: 自定义Adapter来绑定城市数据到ListView或RecyclerView,处理点击事件。 3. **...

    关注HTML5安全

    WebWorker使得后台线程处理成为可能,提高了网页性能,但也为分布式拒绝服务(DDoS)攻击和恶意消息传递提供了温床。防范WebWorker攻击的策略包括限制WebWorker的访问范围,验证postMessage的来源,以及避免在处理...

    JS跨域访问解决方案总结

    6. **Web Worker跨域**:Web Worker可以在后台线程中执行脚本,避免阻塞主线程。虽然Worker本身也受同源策略限制,但可以通过导入`importScripts()`来加载跨域脚本。服务器需要通过设置`Access-Control-Allow-Origin...

    Android Code优化整理1

    Android的support-annotations库提供了一系列注解,如@NonNull、@Nullable用于检查空指针,@StringRes、@DrawableRes等资源注解用于确保资源引用的正确性,@UiThread和@WorkerThread用于线程控制,@CallSuper确保...

    安卓开发-抖动窗口.zip

    例如,减少布局嵌套,使用高效的视图结构,以及避免在主线程进行耗时计算。 4. **RenderThread** RenderThread是Android自Lollipop版本引入的新特性,用于分离UI渲染与主线程。这样可以避免渲染工作阻塞UI更新,...

    从入门到精通HTML5——PDF——网盘链接

     4.7.2 无序列表和有序列表的嵌套 78  4.8 小结 79  4.9 习题 80  第5章 超链接 81  教学录像:22分钟  5.1 超链接的基本知识 82  5.1.1 超链接 82  5.1.2 绝对路径 82  5.1.3 相对路径 82  5.2 超链接的...

    apacheApache 2.0 手册

    2. **线程支持**:在Apache 2.0中,服务器支持多线程处理模型(MPM,Multi-Processing Modules),如`prefork`和`worker` MPM。这提高了并发性能,尤其在内存资源充足时,`worker` MPM的线程模型表现更优。 3. **...

    java面试基础

    问题84中介绍了如何创建一个自定义线程`WorkerThread`。该类继承自`Thread`,在构造函数中接收一个`message`参数并在构造时打印。在`main`函数中通过`start()`方法启动线程,而非`run()`,这是因为`start()`会自动...

Global site tag (gtag.js) - Google Analytics