具体面试题

这道面试题是你去任何一家大厂面试几乎都会被问到的问题。如果这道题答不好,那么最后的结果很有可能是凉凉:

请你分析一下,promise,generator,async 三者之间的关系?

下面有个计时器任务,请用这三种方法依次解决它代码中出现回调地狱的问题。

回调地狱

回调嵌套,代码大量使用了回调函数(将一个函数作为参数传递给另个函数)并且有许多 })结尾的符号,使得代码看起来很混乱。

let t = setTimeout(()=>{
 console.log(1111)
    let t1 = setTimeout(()=>{
        console.log(2222)
        let t2 = setTimeout(()=>{
            console.log(3333)
        },3000)
    },2000)
},1000)

promise

promise 是一个类函数。当它执行完毕后,会开启异步任务,这个异步任务还得看 promise 本身的状态。通俗来说,它的异步任务就是 then 中的回调函数。

那么问题来了。promise 诞生的目的不是为了开启异步任务,而是为了解决异步代码的书写格式,尽量实现函数回调的扁平化,所以我们需要把异步代码写在 promise 中进行封装。

const fnasync = function(value){
      return new Promise(function(resolve,reject){
          setTimeout(()=>{
              console.log(value)
              resolve()
          })
      })
    }
    fnasync(1111, 1000)
    .then(() => {
      return fnasync(2222, 2000)
    })
    .then(() => {
      return fnasync(3333, 3000)
    }).catch(err => {console.log(err)})

async

async 可以算是异步解决的终结者。虽然 promise 效果出来了,但还是会给开发者们带来逻辑上的问题。相反,async 的书写格式简单明了。

let asyncfn = function (num,timecount) {
  return new Promise((resolve,reject)=>{
      setTimeout(function(){
          console.log(num)
          resolve();
      },timecount)
  })
}
let fn = async function(){
  await asyncfn(1111,1000)
  await asyncfn(2222,1000)
  await asyncfn(3333,1000)
}
fn()

我们只需要关注 await 后面跟的内容就 ok 了。

generator

generator是es6中的一个新的语法。在function关键字后添加*即可将函数变为generator

这种特性允许用 function 声明一个生成器,生成器执行后返回一个迭代器(f),和普通的函数不同,生成器内可以使用 yield 关键字而不是return。当我们第一次执行 f.next() 时,函数一直执行到 yield 关键字,暂停整个函数的执行,并且返回 yield 语句的值。当第二次调用 f.next() 时则从上次暂停的地方继续执行,直到下次碰到 yield 或者执行完毕。

function* gen(){
  for (let i = 1; i < 4; i++) {
    yield i*1111;
  }
}

let fs = gen()

console.log(fs.next().value)
console.log(fs.next().value)
console.log(fs.next().value)

它们的联系

对于这三者之间的联系,其实很好理解。我们可以认为它们是每一次版本升级的产物。

也就是说,generator 其实是 promise 的升级版,但它的逻辑和理解却要比 promise 复杂。因此,程序员们在上面要花费一些学习成本,所以不推荐大家使用generator。

而 async 是 generator 的升级版,外界都称它为 generator 的语法糖,那就意味着 async 就是一个小甜点,人人喜欢,因为它简单易懂还好用,顺理成章成为开发者们解决异步方案的不二之选!

最后修改:2021 年 03 月 27 日 10 : 20 AM
如果觉得我的文章对你有用,请随意赞赏
END