一尘不染

同步编程和异步编程之间有什么区别(在node.js中)

node.js

我一直在阅读nodebeginner, 并且遇到了以下两段代码。

第一个:

    var result = database.query("SELECT * FROM hugetable");
    console.log("Hello World");

第二个:

    database.query("SELECT * FROM hugetable", function(rows) {
       var result = rows;
    });
    console.log("Hello World");

我得到了他们应该做的事情,他们查询数据库以检索查询的答案。然后console.log('Hello world')

第一个应该是同步代码。第二个是异步代码。

这两部分之间的区别对我来说很模糊。输出是什么?

搜寻异步编程也无济于事。


阅读 348

收藏
2020-07-07

共1个答案

一尘不染

区别在于,在第 一个示例中 ,程序将在第一行中阻塞。下一行(console.log)必须等待。

第二个示例中
console.log将在处理查询时执行。也就是说,查询将在后台处理,而程序将执行其他操作,并且一旦查询数据准备就绪,您将可以使用它进行任何操作。

简而言之:第一个示例将阻止,而第二个示例则不会。

以下两个示例的输出:

// Example 1 - Synchronous (blocks)
var result = database.query("SELECT * FROM hugetable");
console.log("Query finished");
console.log("Next line");


// Example 2 - Asynchronous (doesn't block) 
database.query("SELECT * FROM hugetable", function(result) {
    console.log("Query finished");
});
console.log("Next line");

将是:

  1. Query finished
    Next line

  2. Next line
    Query finished

注意
虽然Node本身是 单线程的 ,但有些任务可以并行运行。例如,文件系统操作在不同的过程中发生。

这就是为什么Node可以执行异步操作的原因:一个线程在执行文件系统操作,而Node的主线程一直在执行您的JavaScript代码。在节点等事件驱动的服务器中,文件系统线程将某些事件(例如完成,失败或进度)以及与该事件相关的任何数据(例如数据库查询或错误的结果)通知主节点线程。消息),然后由主节点线程决定如何处理该数据。

2020-07-07