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

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.
主站蜘蛛池模板: 修文县| 阳泉市| 上犹县| 安仁县| 台前县| 汤阴县| 娱乐| 汤阴县| 巨鹿县| 府谷县| 大丰市| 盐边县| 隆子县| 巴南区| 庐江县| 阿合奇县| 蓬莱市| 柘荣县| 临湘市| 盐池县| 彭山县| 北宁市| 家居| 安新县| 东阿县| 蕉岭县| 苗栗县| 郧西县| 防城港市| 宝坻区| 海门市| 许昌县| 南安市| 印江| 星座| 绥棱县| 日喀则市| 宝鸡市| 宁远县| 区。| 兴义市|