业界 作者:SegmentFault 2022-04-24 15:06:34 阅读:1060
作者:小江不可求
来源:SegmentFault 思否社区
重复调用IO操作,判断IO是否结束(任务轮询:read、select、poll、kqueue、event ports)因为在轮询的过程中,程序再等待IO的结果,对于代码而言,还是同步的效果。
文件IO: 放入到node实现的线程池中 异步网络IO: 利用到了node的核心库libuv库 可判断所运行的平台 根据平台调用不同的异步IO处理的方法 (做到了类似于跨平台的效果)



const EventEmitter = require('events');
const emitter = new EventEmitter();
// 订阅1
emitter.on('event',(result)=>{
console.log('event1 fired');
console.log(result);
})
// 订阅2
emitter.on('event',(result)=>{
console.log('event2 fired');
})
// 发布
emitter.emit('event','event_result');
/*结果
event1 fired
event_result
event2 fired
*/
const http = require('http');
function sleepTime(time){
const sleep = Date.now() + time * 1000;
// 同步代码,等待时间
while(Date.now() < sleep){};
return;
}
sleepTime(4);
const server = http.createServer((req,res)=>{
res.end('server starting ...');
});
server.listen('8080',()=>{
console.log('服务启动了');
})


