深度理解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函数,所以看到了上面的结果。
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值