使用 thunk:为什么我的代码没有按顺序打印?

Using thunks: Why isn't my code printing sequentially?

我正在尝试理解 thunks。我正在学习 Kyle Simpson 在 Lynda 上的 Rethinking Async JS 课程。

我有这个代码:

function makeThunk(fn) {
    var args = [].slice.call(arguments, 1);
    return function(cb) {
        args.push(cb);
        fn.apply(null, args);
    }
}

function addAsync(x,y, cb) {
    setTimeout(function() {
        cb(x+y);
    }, 1000);
}


var thunk = makeThunk(addAsync, 10,15);

现在,当我执行以下命令时:

thunk(function(sum) {
    console.log(sum * sum);
})

thunk(function(sum) {
    console.log(sum);
})

结果是625打印了两次

然而,当我执行

thunk(function(sum) {
    console.log(sum);
})
thunk(function(sum) {
    console.log(sum * sum);
})

结果25执行了两次

在第一种情况下,我的期望是先打印 625,然后再打印 25。在第二种情况下,先打印 25,然后再打印 625。

为什么我的预期不正确?

var thunk = makeThunk(addAsync, 10,15);

关闭后的args数组为:

[10, 15]

现在如果你调用 thunk :

thunk(function one(sum) {
console.log(sum * sum);
})

内部参数是:

[10, 15, one]

并且函数是第一次执行。然后你打电话:

thunk(function two(sum) {
  console.log(sum);
})

所以 args 看起来像这样:

[10, 15, one, two]

所以 addAsync 的调用方式如下:

addAsync(10, 15, one, two)

所以cb又是一个,因此第一个函数执行了两次。


要解决此问题,您可能需要通过推送更改修改为非可变连接:

return function(cb) {
    fn.apply(null, args.concat(cb));
}