nodejs setTimeout函数使用

node.js,说简单点,基于Google V8引擎的,运行在服务器端的JavaScript。

具有单线程、非阻塞IO、事件驱动等特性。

学习的这几天,感受最深的还是非阻塞IO。由于采用Google V8引擎,node.js可以异步处理数据,举个最简单的例子。

1
2
3
4
5
6
7
8
setTimeout(function(){console.log('5')},5000);
console.log('1');
function test(){
setTimeout(function(){console.log('2')},1000);
}
test();
console.log('3');
setTimeout(function(){console.log('4')},2000);

如果是阻塞IO,程序按行顺序执行,每行执行完再去执行下一行。

运行结果为5,1,2,3,4。运行时间约为8000ms。

node.js采用非阻塞IO,程序按顺序执行,但并不等待当前代码执行完毕,即IO不阻塞。

1
2
3
4
5
6
[root@asxzy nodejs]# node test.js
1
3
2
4
5

运行结果为1,3,2,4,5。运行时间约为5000ms

这就是非阻塞IO所带来的好处,永远不会产生死锁,因为它本身没有锁机制。

同时,非阻塞IO也对变成带来的一些问题:

过程式编程中,有很多情况下是本句代码要求先前的代码执行完毕,如要调用之前处理的数据结果、和数据库交互等。

node.js中可以采用回调方式解决这个问题。

比如

1
setTimeout(function(){console.log('5')},5000);

在执行完5000ms的Timeout之后,调用function(){console.log(’5′)}

 

很好理解了吧!!

posted on 2013-08-29 11:31  joygpwan  阅读(28939)  评论(0编辑  收藏  举报

导航