zoukankan      html  css  js  c++  java
  • HTML5新功能之八 《web works多线程》

    一、多线程

      js是单线程的去跑代码,比如如果做一个循环从0到1亿相加然后输出,浏览器可能会最后到假死(无响应状态),也可以非常慢,

      在FF下测试使用了:3986ms  如果使用web worker来处理,只需要1ms

     1 <div id="box"></div>
     2 <input type="button" id="beginBtn" value="开始">
     3 <input type="button" id="endBtn" value="停止">
     4 
     5 <script>
     6     function getId(id){
     7         return document.getElementById(id);
     8     }
     9 
    10     var oBeginBtn = getId("beginBtn");
    11     var oEndBtn = getId("endBtn");
    12     var oBox = getId("box");
    13     var temp = 0;
    14 
    15     var worker = new Worker("count.js");
    16 
    17     // 接收从线程中传出的计算结果
    18     /*
    19     worker.onmessage = function(event){
    20         // 消息文本放置在data属性中,
    21         oBox.innerHTML = event.data;
    22     }
    23     */
    24 
    25     oBeginBtn.onclick = function(){
    26         console.time('a');
    27 
    28         // 将数据传给线程
    29         worker.postMessage(100000000);
    30 
    31         worker.onmessage = function(event){
    32             // 消息文本放置在data属性中,
    33             oBox.innerHTML = event.data;
    34         }
    35 
    36         console.timeEnd('a');
    37 
    38     }
    39 </script>

    count.js

     1 onmessage = function(event){
     2     var num = event.data;
     3     var result = 0;
     4     for(var i=0; i<num; i++){
     5         result += i;
     6     }
     7 
     8     // 向线程创建源送回消息
     9     postMessage(result);
    10 }

    1、postMessage(msg):向创建线程的源窗口发消息

    2、onmessage:获取接收消息的事件

    3、importScripts():导入其它js脚本,参数为脚本文件的url,可以导入多个脚本文件

    4、close():结束线程

    4、navigator对象:

      可以在localStorage和sessionStorage

      XMLHttpRequest可以在线程中使用ajax

      setTimeout、setinterval():定时器可以使用线程 

  • 相关阅读:
    Hyperion Planning 表单数据验证功能实现
    类型别名
    内联函数和constexpr函数
    强制类型转换
    当函数返回值是引用
    左值和右值
    const形参和实参
    const限定符
    auto与decltype
    局部对象
  • 原文地址:https://www.cnblogs.com/couxiaozi1983/p/3799898.html
Copyright © 2011-2022 走看看