SHOEISHA iD

※旧SEメンバーシップ会員の方は、同じ登録情報(メールアドレス&パスワード)でログインいただけます

CodeZine編集部では、現場で活躍するデベロッパーをスターにするためのカンファレンス「Developers Summit」や、エンジニアの生きざまをブーストするためのイベント「Developers Boost」など、さまざまなカンファレンスを企画・運営しています。

マンガで分かるプログラミング用語辞典

「Web Workers」
~マンガでプログラミング用語解説

マンガで分かるプログラミング用語辞典(138)

  • X ポスト
  • このエントリーをはてなブックマークに追加

解説

 「Web Workers」は、Webページでスクリプトを、バックグラウンドのスレッドで実行するための手段です。

 JavaScriptは、シングルスレッドのプログラミング言語です。そして、実行中は、WebブラウザのUIなどの処理を停止させます。Web Workersは、こうした問題を解決して、他のスレッドで計算を行うためのものです。

 Web Workersに対応しているWebブラウザでは、window.Workerオブジェクトを、ファイルのURIを引数にして初期化することで、Web Workersの機能を利用できます。

サンプル

 「Web Workers」のサンプルです。ファイルはUTF-8で保存してください。検証はGoogle Chromeで行っています。

 1つ目は、Web Workersを利用しないサンプルで、重い処理を実行している間、スクロールができなくなります。2つ目は、Web Workersを利用したサンプルで、重い処理を実行している間も、スクロールができます。

 セキュリティ上の理由で、Webブラウザによっては、138_js2.htmlからtask.jsの読み込みがサーバー上でしかできません。サンプルの利用は、サーバー上で行ってください。

138_js1.html
<!DOCTYPE html>
<html lang="ja">
    <head>
        <meta charset="UTF-8">
        <title>「Web Workers」のサンプル1 - Web Workers なし</title>
        <script src="https://code.jquery.com/jquery-3.3.1.min.js"></script>
    </head>
    <body>
        <script>
        // 重い処理を実行している間、スクロールできない
        $(function() {
            setTimeout(function() {
                $('#out').append('start<br>');
                setTimeout(function() {
                    var len = 500000000;
                    var n = 0;
                    for (var i = 0; i < len; i ++) {
                        if (len % i === 0) n ++;
                    }
                    $('#out').append('end ' + n);
                }, 100);
            }, 1000);
        });
        </script>
        <div id="out" style="position: fixed;">output:<br></div>
        <div style="height: 3000px;"></div>
    </body>
</html>
138_js2.html
<!DOCTYPE html>
<html lang="ja">
    <head>
        <meta charset="UTF-8">
        <title>「Web Workers」のサンプル2 - Web Workers あり</title>
        <script src="https://code.jquery.com/jquery-3.3.1.min.js"></script>
    </head>
    <body>
        <script>
        // 重い処理を実行していても、スクロールできる
        var worker = new Worker('task.js');
        $(function() {
            setTimeout(function() {
                $('#out').append('start<br>');
                setTimeout(function() {
                    worker.onmessage = function(e) {
                        $('#out').append('end ' + e.data);
                    };
                    worker.postMessage(500000000);

                }, 100);
            }, 1000);
        });
        </script>
        <div id="out" style="position: fixed;">output:<br></div>
        <div style="height: 3000px;"></div>
    </body>
</html>
task.js
onmessage = function (e) {
    var len = e.data;
    var n = 0;
    for (var i = 0; i < len; i ++) {
        if (len % i === 0) n ++;
    }
    postMessage(n);
};
フィードバックお待ちしております!

 ご感想、解説して欲しい用語、解説内容のアドバイスなどございましたら、FacebookTwitterなどでお気軽に編集部までお寄せください。よろしくお願いいたします。

この記事は参考になりましたか?

  • X ポスト
  • このエントリーをはてなブックマークに追加
マンガで分かるプログラミング用語辞典連載記事一覧

もっと読む

この記事の著者

柳井 政和(ヤナイ マサカズ)

クロノス・クラウン合同会社 代表社員http://crocro.com/オンラインソフトを多数公開。プログラムを書いたり、ゲームを作ったり、記事を執筆したり、マンガを描いたり、小説を書いたりしています。「めもりーくりーなー」でオンラインソフト大賞に入賞。最近は、小説家デビューして小説も書いています(『裏切りのプログラム』他)。面白いことなら何でもOKのさすらいの企画屋です。 

※プロフィールは、執筆時点、または直近の記事の寄稿時点での内容です

この記事は参考になりましたか?

この記事をシェア

  • X ポスト
  • このエントリーをはてなブックマークに追加
CodeZine(コードジン)
https://codezine.jp/article/detail/10956 2018/09/25 14:00

おすすめ

アクセスランキング

アクセスランキング

イベント

CodeZine編集部では、現場で活躍するデベロッパーをスターにするためのカンファレンス「Developers Summit」や、エンジニアの生きざまをブーストするためのイベント「Developers Boost」など、さまざまなカンファレンスを企画・運営しています。

新規会員登録無料のご案内

  • ・全ての過去記事が閲覧できます
  • ・会員限定メルマガを受信できます

メールバックナンバー

アクセスランキング

アクセスランキング