下面这段疯狂的代码,你能知道它输出什么结果吗?
123456789101112131415161718192021222324252627282930 | 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(); |
测试速度:
123456 | 42hash: 785FS: 785hash: 788hash: 790hash: 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协议 许可协议。转载请注明出处!
亿速云「云服务器」,即开即用、新一代英特尔至强铂金CPU、三副本存储NVMe SSD云盘,价格低至29元/月。点击查看>>
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。