-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathscript.js
30 lines (23 loc) · 1.04 KB
/
script.js
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
import { Worker } from 'node:worker_threads'
import { processByChunks, processLineByLine } from './shared.js'
export async function processLineByLineWorker(id) {
return new Promise((resolve) => {
const worker = new Worker('./worker-lines.js', { workerData: { id } })
worker.on('message', resolve)
})
}
export async function processByChunksWorker(id) {
return new Promise((resolve) => {
const worker = new Worker('./worker-chunks.js', { workerData: { id } })
worker.on('message', resolve)
})
}
// PLAYGROUND ---------------------------------------------------------------------------
// processLineByLine(0)
// processByChunks(0)
// processLineByLineWorker(0)
// processByChunksWorker(0)
// Promise.all(new Array(20).fill(null).map((_, index) => processLineByLine(index)))
// Promise.all(new Array(20).fill(null).map((_, index) => processLineByLineWorker(index)))
// Promise.all(new Array(20).fill(null).map((_, index) => processByChunks(index)))
Promise.all(new Array(20).fill(null).map((_, index) => processByChunksWorker(index)))