深度理解nodejs[3]—疯狂事件代码
下面这段疯狂的代码,你能知道它输出什么结果吗?
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
const https = require('https');
const start = Date.now();
const fs = require('fs');
const crypto = require('crypto');
function dorequest(){
https.request('https://www.baidu.com',res=>{
res.on('data',()=>{});
res.on('end',()=>{
console.log(Date.now()-start);
});
})
.end();
}
function dohash(){
crypto.pbkdf2('a','b',100000,512,'sha512',()=>{
console.log('hash:',Date.now()-start);
});
}
dorequest();
fs.readFile('test.js','utf8',()=>{
console.log('FS:',Date.now()-start);
});
dohash();
dohash();
dohash();
dohash();
测试速度:
1
2
3
4
5
6
42
hash: 785
FS: 785
hash: 788
hash: 790
hash: 790
解释:
https不依靠libuv库的4个默认线程,操作系统资源。其第一个最快的执行完毕
FS和pbkdf2都使用了libuv中的线程池
一开始FS与三个pbkdf2抢占了libuv线程池的4个线程,但是由于FS读取文件,中断操作。libuv将线程切换到执行最后一个pbkdf2函数。
等到某一个pbkdf2函数执行完毕后,则继续执行FS函数,所以看到了上面的结果。
本文链接:https://dreamerjonson.com/2018/11/09/深度理解nodejs-3-—疯狂事件代码/
版权声明:本博客所有文章除特别声明外,均采用CC BY 4.0 CN协议许可协议。转载请注明出处!
声明:本站所有文章资源内容,如无特殊说明或标注,均为采集网络资源。如若本站内容侵犯了原著者的合法权益,可联系本站删除。