关于node.js同步异步的理解与实例

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等)则是可以并行起来的。

posted @ 2020-03-11 20:08  轩竹乙  阅读(431)  评论(0编辑  收藏  举报