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

Blocking and non-blocking software development

Let's go ahead and take a look at the differences between blocking and non blocking software development:

In the preceding screenshot, I have two files that we'll be executing. But before going to that, first let's explore how each of these files operates, the steps that are required in order to finish the program.

This will help us understand the big differences between blocking, which I have on the left side of the image, which is not what Node uses, and non-blocking is on the right side, which is exactly how all of our Node applications in the book are going to operate.

You don't have to understand the individual details, such as what require is, in order to understand what's going on in this code example. We'll be breaking things down in a very general sense. The first line on each code is responsible for fetching a function that gets called. This function will be our simulated I/O function that is going to a database, fetching some user data and printing it to the screen.

Refer to the preceding code image. After we load in the function, both files try to fetch a user with an ID of 123. When it gets that user, it prints it to the screen with the user1 string first, and then it goes on and it fetches the user with 321 as the ID. And it prints that to the screen. And finally both files add up 1 + 2, storing the result, which is 3, in the sum variable and print it to the screen.

Now, while they all do the same thing, they do it in very different ways. Let's break down the individual steps. In the following code image, we'll go over what Node executes and how long it takes:

You can consider the seconds shown in the preceding screenshot; it doesn't really matter, it's just to show the relative operating speed between the two files.

主站蜘蛛池模板: 定结县| 图们市| 汉中市| 望谟县| 肥西县| 和政县| 洪泽县| 南充市| 海淀区| 南通市| 德阳市| 香格里拉县| 德化县| 定西市| 唐海县| 济源市| 江孜县| 拜城县| 铜山县| 焉耆| 盱眙县| 乌兰浩特市| 汉寿县| 栾城县| 南开区| 塘沽区| 济阳县| 米易县| 云南省| 石城县| 文化| 民丰县| 三都| 建瓯市| 海淀区| 通江县| 仁怀市| 万年县| 深泽县| 伊吾县| 开阳县|