深度理解nodejs[3]—疯狂事件代码-创新互联
疯狂的代码。
下面这段疯狂的代码,你能知道它输出什么结果吗?
![](/upload/ad_content/xuanchuantu-15.jpg)
创新互联公司长期为上1000家客户提供的网站建设服务,团队从业经验10年,关注不同地域、不同群体,并针对不同对象提供差异化的产品和服务;打造开放共赢平台,与合作伙伴共同营造健康的互联网生态环境。为河东企业提供专业的网站设计制作、
网站建设,
河东网站改版等技术服务。拥有十多年丰富建站经验和众多成功案例,为您定制开发。
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函数,所以看到了上面的结果。
![深度理解nodejs[3]—疯狂事件代码](/upload/otherpic36/239201.jpg)
创新互联www.cdcxhl.cn,专业提供香港、美国云服务器,动态BGP最优骨干路由自动选择,持续稳定高效的网络助力业务部署。公司持有工信部办法的idc、isp许可证, 机房独有T级流量清洗系统配攻击溯源,准确进行流量调度,确保服务器高可用性。佳节活动现已开启,新人活动云服务器买多久送多久。
网站标题:深度理解nodejs[3]—疯狂事件代码-创新互联
本文来源:
http://csdahua.cn/article/dcdjpi.html
扫二维码与项目经理沟通
我们在微信上24小时期待你的声音
解答本文疑问/技术咨询/运营咨询/技术建议/互联网交流