开发者

Don't understand the callback and non-blocking example - Node.js

In the book Hands-on node, the author gives an example of blocking I\O,

var post = db.query("select * from posts w开发者_如何学Gohere id = 1");
doSomethingWithPost(post)
doSomethingElse();

The author says nothing is executed till line 1 is finished executing db query

And, then he shows non-blocking code

callback = function(post){
doSomethingWithPost(post)
}

db.query("select * from posts where id = 1",callback);
doSomethingElse();

Isn't this also blocking till the query is executed?

So, doSomethingElse won't be executed till query is completed.


You should always read non-blocking functions like doRealStuff( params, callback ) as "put doRealStuff, params and callback in the queue, do callback() when reached queue end". This also may help avoid doing mistakes like

for (var i=0; i < 1000000; i++)
{
    // I want to do many http requests now
    do_request(test_url);
}

// not a single byte is sent here because event loop was blocked by for loop


The author is absolutely correct. If the second example is non-blocking, the code execution will trigger the query and then continue executing the rest of the code. The callback function will be called after the query is complete, at some undetermined point in the future. doSomethingElse(); will be called immediately.

What actually makes this example blocking vs non-blocking is not clear in the examples you have provided. It will be something internal to the DB implementation. Perhaps by passing in a callback parameter you are indicating that the request should be non-blocking.

Hopefully that helps, tyler.


Ryan Dahl's intro is a pretty good overview, but this beginner's tutorial is excellent, it explains in detail and in a friendly way the premise of non/blocking operations in Javascript (and so Node).

But in a nutshell, the callback parameter in the 2nd example you've posted isn't executed until db.query finishes, it is "held on to for later", which means code after the db.query() call can continue to be executed.

0

上一篇:

下一篇:

精彩评论

暂无评论...
验证码 换一张
取 消

最新问答

问答排行榜