我一直在阅读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')。
console.log('Hello world')
第一个应该是同步代码。第二个是异步代码。
这两部分之间的区别对我来说很模糊。输出是什么?
搜寻异步编程也无济于事。
区别在于,在第 一个示例中 ,程序将在第一行中阻塞。下一行(console.log)必须等待。
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");
将是:
Query finished Next line
Query finished
Next line
Next line Query finished
注意 虽然Node本身是 单线程的 ,但有些任务可以并行运行。例如,文件系统操作在不同的过程中发生。
这就是为什么Node可以执行异步操作的原因:一个线程在执行文件系统操作,而Node的主线程一直在执行您的JavaScript代码。在节点等事件驱动的服务器中,文件系统线程将某些事件(例如完成,失败或进度)以及与该事件相关的任何数据(例如数据库查询或错误的结果)通知主节点线程。消息),然后由主节点线程决定如何处理该数据。