如何在Javascript中编写非阻塞回调

How to write a non-blocking callback in Javascript?

本文关键字:回调 Javascript      更新时间:2023-09-26

下面是我正在尝试的一些代码:

startTask();
function startTask(){
    console.log('startTask enter');
    startLongTask(1, function(){
        console.log('long task complete');
    });
    console.log('startTask exit');
}
function startLongTask(i, callback) {
    while (i++ < 10000){
        console.log(i);
    }
    callback();
}

这里是输出(省略了数字的大序列):

startTask enter
2
3
4
5
6
7
8
9
10
long task complete
startTask exit

很明显,如果我有一个长期运行的操作,它是同步的。这就像在startTask中内联startLongTask。如何将此回调修复为非阻塞。我期望的输出是:

startTask enter
startTask exit
2
3
4
5
6
7
8
9
10
long task complete

Javascript纯代码无法在纯JS中创建新的异步操作,因为node.JS中的V8解释器没有为您提供完整的线程。

node.js中的fs模块等库从本机操作(js/V8世界之外)获得异步行为,并通过异步接口与js引擎接口。

也就是说,有一些方法可以通过使用一些非js代码在node.js中的后台运行操作。你可以启动另一个进程,你可以使用各种支持其他执行线程的附加模块,等等。所有这些都将超出纯node.js Javascript,以便提供异步接口。

如果你的任务可以分成小段,你也可以通过在连续的定时器上做少量的工作来模拟异步操作(这也是浏览器中常见的解决方法)。

您可以使用延迟0毫秒的超时函数。超时中的任何函数都将被推送到执行线程的末尾。例如

startTask();
function startTask(){
    console.log('startTask enter');
    setTimeout(function(){
        startLongTask(1, function(){
            console.log('long task complete');
        })
    }, 0);
    console.log('startTask exit');
}
function startLongTask(i, callback) {
    while (i++ < 100){
        console.log(i);
    }
    callback();
}