设为首页 - 加入收藏
广告 1000x90
您的当前位置:三五图库香港35图库大全 > 并行计算 > 正文

Mozilla 正在 SpiderMonkey 中测试 JavaScript 并行计算

来源:未知 编辑:admin 时间:2019-05-09

  他们试图通过一种底层的、渐进的方法为 JavaScript 添加更加灵活和强大的并行计算原语。他首先指出:

  这里要探讨的是可以释放设备(GPU、SIMD 指令及多内核处理器)潜能的并行计算。Web Workers已经在多核并行计算方面做了一些工作,但其工作线程是完全隔离的,只能通过postMessage进行通信。

  还有一种方案比较激进,就是像Nashorn那样将 JavaScript 变成一种完全多线程的数据模型。不过,那需要宿主 Java 程序小心地同步脚本,否则,JavaScript 应用程序无法得到“运行至完成(run-to-completion)”的保证。而且,这个过程会伴随大量的标准化和实现工作,进而会带来生态系统方面的风险。

  另一方面,Mozilla Research 和 Intel Labs 这些年来也在确定性并行计算 API(有人称为River TrailPJS)方面做了一些实验。但他们选择了一种很困难的方法,因为很难找到一种足够通用的高级模型能够适合各式各样的并行程序。

  于是,他们引入了 SharedArrayBuffer 类型。不同于 PJS,它内置的锁定机制为工作线程带来了新的锁定形式,但同样地,部分对象也可能因此遭受数据争用。不过,与 Nashorn 不同的是,这种情况只会出现在选择使用共享内存作为后台存储的对象中。如果创建了一个不使用共享缓冲区的对象,那么可以确定,它永远不会出现数据争用。Dave 表示,这是一种相对保守的方法,但应该能够满足许多应用场景的需求。实际上,几年前就有人探讨过这种方法。在去年的JSConf大会上,谷歌 PNaCI 团队的 Nick Bray 还演示了一个在 Chrome 中共享缓冲区的原型。

  目前,Dave 及其团队正在 SpiderMonkey 中测试 SharedArrayBuffer API,并且正在草拟它的规范Firefox 每日构建版本中已经提供了原型实现,感兴趣的读者可以下载试用并提供反馈。

  给 InfoQ 中文站投稿或者参与内容翻译工作,请邮件至也欢迎大家通过新浪微博(@InfoQ)或者腾讯微博(@InfoQ)关注我们,并与我们的编辑和其他读者朋友交流。

本文链接:http://1763inn.com/bingxingjisuan/558.html

相关文章:

相关推荐:

网友评论:

栏目分类

现金彩票 联系QQ:24498872301 邮箱:24498872301@qq.com

Copyright © 2002-2011 DEDECMS. 现金彩票 版权所有 Power by DedeCms

Top