async函数默认返回Promise,这是语言规范强制规定:无论是否显式return,其返回值均被Promise.resolve()包装;无return时等价于Promise.resolve(undefined),且执行体作为微任务异步调度。

async函数默认返回Promise,这是JavaScript中async/await机制的核心设计之一。无论函数体内部是否显式使用return,只要用async声明,调用它就会立即返回一个Promise对象。
为什么async函数总是返回Promise?
这是语言规范强制规定的:async函数的执行结果会被自动包装进Promise.resolve()。即使你return一个普通值(比如字符串或数字),它也会被转为fulfilled状态的Promise;如果函数体内抛出异常,或return一个被reject的Promise,那返回的Promise就是rejected状态。
- return 42 → Promise.resolve(42)
- return Promise.resolve("ok") → 等价于 Promise.resolve("ok")(会等待并透传)
- throw new Error("fail") → Promise.reject(new Error("fail"))
- return Promise.reject("error") → Promise.reject("error")
不写return时的默认行为
如果async函数没有return语句,等价于return undefined,因此返回的是Promise.resolve(undefined)。这和普通函数默认返回undefined一致,只是多了一层Promise包装。
例如:
立即学习“Java免费学习笔记(深入)”;
async function foo() {}console.log(foo()); // Promise {undefined}
与普通Promise构造的差异
async函数返回的Promise是“已调度”的:它的执行体(即函数体)会在当前任务队列末尾异步执行(微任务),但Promise实例本身是同步创建并返回的。你可以立刻对它调用.then()或await,而无需担心未定义问题。
对比手动new Promise时需要自己控制resolve/reject时机,async让异步流程更简洁、错误处理更统一(try/catch可捕获await中的reject)。
实际使用中的注意事项
因为返回值一定是Promise,所以不能直接获取最终值,必须用await或.then()消费:
- ❌ const val = asyncFn(); // 得到的是Promise,不是val本身
- ✅ const val = await asyncFn(); // 在async上下文中
- ✅ asyncFn().then(val => console.log(val)); // 在非async环境中
另外,多个async函数连续调用时,它们的Promise链天然可组合,适合串行或并行异步操作。










