Node.js: While Loop Callback Not Working As Expected
Solution 1:
Javascript and node.js are single threaded, which means a simple while
blocks; no requests/events can be processed until the while
block is done. Callbacks don't magically solve this problem, they just help pass custom code to a function. Instead, iterate using process.nextTick
, which will give you esentially the same results but leaves space for requests and events to be processed as well, ie, it doesn't block:
functiondoSleep(callback) {
var stop = newDate().getTime();
process.nextTick(function() {
if(newDate().getTime() < stop + 15000) {
//Done, run callbackif(typeof callback == "function") {
callback();
}
} else {
//Not done, keep looping
process.nextTick(arguments.callee);
}
});
}
doSleep(function() {
console.log("done sleeping");
console.log("DONE");
});
Solution 2:
You are calling sleep
right away, and the new sleep
function blocks. It keeps iterating until the condition is met. You should use setTimeout()
to avoid blocking:
setTimeout(function () {
console.log('done sleeping');
}, 15000);
Solution 3:
Callbacks aren't the same thing as asynchronicity, they're just helpful when you want to get a... callback... from an asynchronous operation. In your case, the method still executes synchronously; Node doesn't just magically detect that there's a callback and long-running operation, and make it return ahead of time.
The real solution is to use setTimeout
instead of a busy loop on another thread.
Solution 4:
As already mentioned, asynchronous execution should be achieved by setTimeout() rather than while, because while will freeze in one "execution frame".
Also it seems you have syntax error in your example.
This one works fine: http://jsfiddle.net/6TP76/
Post a Comment for "Node.js: While Loop Callback Not Working As Expected"