Node; Q Promise delay

后端 未结 1 1590
隐瞒了意图╮
隐瞒了意图╮ 2020-12-04 03:35

Here are some simple questions based on behaviour I noticed in the following example running in node:

Q(\'THING 1\').then(console.log.bind(console));
console         


        
相关标签:
1条回答
  • 2020-12-04 04:14

    This is actually done on purpose. It is to make it consistent whether or not the value is known or not. That way there is only one order of evaluation and you can depend on the fact that no matter if the promise has already settled or not, that order will be the same.

    Also, doing it otherwise would make it possible to write a code to test if the promise has settled or not and by design it should not be known and acted upon.

    This is pretty much the as doing callback-style code like this:

    function fun(args, callback) {
    
        if (!args) {
            process.nextTick(callback, 'error');
        }
        // ...
    }
    

    so that anyone who calls it with:

    fun(x, function (err) {
      // A
    });
    // B
    

    can be sure that A will never run before B.

    The spec

    See the Promises/A+ Specification, The then Method section, point 4:

    onFulfilled or onRejected must not be called until the execution context stack contains only platform code.

    See also the the note 1:

    Here "platform code" means engine, environment, and promise implementation code. In practice, this requirement ensures that onFulfilled and onRejected execute asynchronously, after the event loop turn in which then is called, and with a fresh stack. This can be implemented with either a "macro-task" mechanism such as setTimeout or setImmediate, or with a "micro-task" mechanism such as MutationObserver or process.nextTick. Since the promise implementation is considered platform code, it may itself contain a task-scheduling queue or "trampoline" in which the handlers are called.

    So this is actually mandated by the spec.

    It was discussed extensively to make sure that this requirement is clear - see:

    • https://github.com/promises-aplus/promises-spec/pull/70
    • https://github.com/promises-aplus/promises-spec/pull/104
    • https://github.com/promises-aplus/promises-spec/issues/100
    • https://github.com/promises-aplus/promises-spec/issues/139
    • https://github.com/promises-aplus/promises-spec/issues/229
    0 讨论(0)
提交回复
热议问题