官术网_书友最值得收藏!

Non-blocking asynchronous execution

One of the most powerful features of Node.js is that it is both event-driven and asynchronous. So, how does an asynchronous model work? Imagine you have a block of code and at some nth line you have an operation that is time consuming. What happens to the lines that follow the nth line while this code gets executed? In normal synchronous programming models, the lines that follow the nth line will have to wait until the operation at that line completes. An asynchronous model handles this case differently.

Let us visualize this scenario with the help of the following code and diagram:

In the preceding case, the setTimeout() method is provided by JavaScript (Node.js) API. Hence, this method is recognized as synchronous and is executed in a different execution context. According to functionality to setTimeout() , it executes the callback function after a specified duration, in our case after three seconds.

Further, the current execution is never blocked for a process to complete. When Node.js API determines that the completion of an event has been fired, it will execute your callback function at that moment.

In a typical synchronous programming language, executing the preceding code will yield the following output:

If you are still interested in learning more about asynchronous models and the callback concept in JavaScript, Mozilla Developer Network ( MDN) has many articles that explain these concepts in detail.
主站蜘蛛池模板: 安康市| 出国| 绥德县| 砚山县| 封丘县| 中西区| 凭祥市| 基隆市| 廉江市| 马龙县| 永寿县| 镇坪县| 玉屏| 大冶市| 双流县| 鲁山县| 南部县| 明星| 东海县| 慈利县| 永定县| 通化市| 泰州市| 尼勒克县| 固阳县| 澜沧| 新邵县| 南京市| 育儿| 马山县| 四川省| 南靖县| 西青区| 贵南县| 安岳县| 法库县| 五峰| 渑池县| 长顺县| 广丰县| 灵川县|