| ページ一覧 | ブログ | twitter |  書式 | 書式(表) |

MyMemoWiki

TypeScript 並列処理

提供: MyMemoWiki
2020年11月6日 (金) 23:45時点におけるPiroto (トーク | 投稿記録)による版
(差分) ← 古い版 | 最新版 (差分) | 新しい版 → (差分)
ナビゲーションに移動 検索に移動

| TypeScript | Node.js | Angular | Google Cloud Platform |

Web Worker(ブラウザ)

コード

  • scripts/browser_main_thread.ts
let worker = new Worker("/scripts/browser_worker.js");
worker.onmessage = e => {
    console.log(`RECEIVE MESSAGE FROM WORKER:${e.data}`);    
}
worker.postMessage("message to worker!");
  • scripts/browser_worker.ts
onmessage = e => {
    console.log(`RECEIVE MESSAGE FROM MAIN : ${e.data}`);
    postMessage(`Ack:"${e.data}"`);
}
  • index.html
<html>
<head>
    <script src="scripts/browser_main_thread.js"></script>
    <script src="scripts/browser_worker.js"></script>
</head>
<body>
    TEST
</body>
</html>

実行

Typescript multithred.png

子プロセス(Node.js)

  • ブラウザでのWeb Workerと同じ方法で動作

コード

  • node_main_thread.ts
import {fork} from 'child_process';
 
let child = fork('./public/scripts/node_child_process.js');
child.on('message', data => {
    console.log('receive child message: ', data);
});
child.send({message:"PARENT MESSAGE"});
  • node_child_process.ts
process.on('message', data => {
    console.log('receive parent process message : ', data);
});
if (process.send) {
    process.send({message:"CHILD MESSAGE"});
}

実行

$ node public/scripts/node_main_thread.js 
receive parent process message :  { message: 'PARENT MESSAGE' }
receive child message:  { message: 'CHILD MESSAGE' }