1、Webstrom使用node.js IDE的问题node
在区别这两个函数以前来讲一下Webstrom使用node.js IDE的问题,在配置Node.js的IDE了,但setImmediate()、require等这些node.js中内置的函数时并不会有提示,要解决这个问题只要设置一下Webstrom,File---->Setting---->Languages&Frameworks------>Node.js and NPM中的Node.js core Library is not enabled设为Enable.数组
2、二者的区别函数
1.在理解二者的区别以前要说一下轮询ui
前面博客也有记录,nodejs中是事件驱动的,有一个循环线程一直从事件队列中取任务执行或者I/O的操做转给后台线程池来操做,把这个循环线程的每次执行的过程算是一次轮询.spa
2.setImmediate()的使用线程
即时计时器当即执行工做,它是在事件轮询以后执行,为了防止轮询阻塞,每次只会调用一个。3d
3.Process.nextTick()的使用code
它和setImmediate()执行的顺序不同,它是在事件轮询以前执行,为了防止I/O饥饿,因此有一个默认process.maxTickDepth=1000来限制事件队列的每次循环可执行的nextTick()事件的数目。orm
4.总结blog
在网上百度的关于它们的总结:
nextTick()的回调函数执行的优先级要高于setImmediate();
process.nextTick()属于idle观察者,setImmediate()属于check观察者.在每一轮循环检查中,idle观察者先于I/O观察者,I/O观察者先于check观察者.
在具体实现上,process.nextTick()的回调函数保存在一个数组中,
setImmediate()的结果则是保存在链表中.
在行为上,process.nextTick()在每轮循环中会将数组中的回调函数所有执行完.
而setImmediate()在每轮循环中执行链表中的一个回调函数.
5.代码demo
//加入2个nextTick()的回调函数 process.nextTick(function(){ console.log("nextTick延迟执行A"); }); process.nextTick(function(){ console.log("nextTick延迟执行B"); setImmediate(function(){ console.log("setImmediate延迟执行C"); }); process.nextTick(function(){ console.log("nextTick延迟执行D"); }); }); //加入两个setImmediate()回调函数 setImmediate(function(){ console.log("setImmediate延迟执行E"); process.nextTick(function(){ console.log("强势插入F"); }); setImmediate(function(){ console.log("setImmediate延迟执行G"); }); }); setImmediate(function(){ console.log("setImmediate延迟执行H"); process.nextTick(function(){ console.log("强势插入I"); }); process.nextTick(function(){ console.log("强势插入J"); }); setImmediate(function(){ console.log("setImmediate延迟执行K"); }); }); console.log("正常执行L");
输出结果:
"C:\Program Files (x86)\JetBrains\WebStorm 11.0.3\bin\runnerw.exe" F:\nodejs\node.exe Immediate.js 正常执行L nextTick延迟执行A nextTick延迟执行B nextTick延迟执行D setImmediate延迟执行E setImmediate延迟执行H setImmediate延迟执行C 强势插入F 强势插入I 强势插入J setImmediate延迟执行G setImmediate延迟执行K Process finished with exit code 0
关于执行顺序的问题很不容易搞明白,说实话如今我对它仍是不是太理解,但愿有大神能给讲明白。