在async/await概念中,async、detach和asyncDetached函数都可以被用来创建异步任务。下面将阐述它们之间的差别。
async函数用于在当前函数中返回一个Promise对象,执行该函数时会立即返回一个已解析的Promise对象。该函数可以包含await关键字,使得执行流程在等待异步操作完成后再继续执行。当async函数内部抛出一个异常时,该函数将以拒绝的Promise对象被拒绝。
以下是async函数的示例代码:
async function foo() { await someAsyncFunction(); return 'done'; }
detach函数用于创建一个无需等待的后台任务。detach函数会自动分离任务,使得该任务不会阻塞主线程。因此,主线程会继续往下执行,而后台任务将在另一个线程中执行。
以下是detach函数的示例代码:
detach(function() { // long-running task });
asyncDetached函数用于创建一个async任务,并将其作为一个后台任务分离出去,使得该任务不会阻塞主线程。这个函数会返回一个Promise对象,该Promise对象的解析值是async函数的返回值。asyncDetached函数还可以通过将一个回调函数传递给它来处理返回值。
以下是asyncDetached函数的示例代码:
asyncDetached(async function() { await someAsyncFunction(); return 'done'; }).then(result => { console.log(result); });