Node.js 同步
同步的概念通俗的说就是代码以此往下执行,也就是阻塞是 I/O,I/O 操作一般是读写文件、输入输出、请求响应等等。
function waitfive(name,function_name){ var pus = 0 vat currentDate = new Date() while(pus < 3000){ vat now = new Date() pus = now -currentDate } function_name(name) } function echo(name){ console.log(name) } waitfive("hellow",echo); console.log("wold")
这个先等待3秒钟然后打印出hellow和wold,这就是同步
Node.js 异步
异步就是非阻塞式
我们知道,node.js是单线程的脚本语言,单线程存在着一些局限性,科颜氏node.js它是非阻塞式的I/O。
node.js的I/O请求都是异步的,当我们发出指令的操作后我们的程序可以继续往下执行,等到操作完成后执行回调。
function Person(){
this.think = function(callback){
setTimeout(function(){
console.log("person is thinking")
callback()
},3000)
}
this.answer = function(){
console.log("I am an answer");
}
}
var person = new Person()
person.think(function(){
console.log("think 3秒……")
})
person.answer()
以上代码会先打印出 i am an answer 三秒后打印出 person is thinking 和 think 3秒……
这就是node.js 异步操作
总结
异步I/O的几个关键词:单线程、事件循环、观察者和I/O线程池。
这里单线程与I/O线程池之间看起来有些悖论的样子。由于我们知道javascript是单线程的,所以按常识很容易理解为它不能充分利用多核CPU。事实上,在Node中,除了JavaScript是单线程外,Node自身其实是多线程的,只是I/O线程使用的CPU较少。另一个需要重视的观点则是,除了用户代码无法并行执行外,所有的I/O(磁盘I/O和网络I/O等)则是可以并行起来的。