1. 同步API,异步API
同步API:只有当API执行完成后,才能继续执行下一个API
console.log('before');
console.log('after');
异步API:当前API的执行不会阻塞后续代码的执行
console.log('before')
setTimeout(
()=>{consloe.log('last');
},2000);
console.log('after');
2. 回调函数
自己定义函数让别人去调用
//getData函数定义
function getData (callback){}
//getData函数调用
getData (()=>{});
异步的执行结果只能通过回调函数获取并处理
3. 回调函数获取异步API执行结果
function getMsg(callback){
setTimeout(function(){
callback ({msg:'Hello Node.js'})
},2000);
}
getMsg(function (msg){
console.log(msg);
})
4. 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等)则是可以并行起来的。