一道阿里/字节真题理解前端异步编程

Posted 前端复习课

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了一道阿里/字节真题理解前端异步编程相关的知识,希望对你有一定的参考价值。


非985/211大学毕业,软件工程专业,前端,坐标:北京
工作三年多,第一家人数 30 多人的创业公司,1 年多。
第二家属于前端技术不错的公司,2 年多。

01

我是一个喜欢在技术领域“折腾”的人,技术能力勉强合格,随着工作经验的积累,逐渐从一个“填坑”的锻炼为可以负责复杂的前端项目。

本想着可以在“金九银十”的时候跳槽成功的,没想到直到年末才拿到自己想要的大厂offer,也算是功夫不负有心人吧,一轮轮面试下来,也是深深感受到了高级前端的面试套路,今天我们一起来探讨一下。
 
跳槽目标:
虽然,我迫切想要换工作,但是也明白裸辞是不明智的,所以“骑驴找马”成为找工作的方式,对于想要换一份怎样的工作,综合考虑以后,我觉得自己的核心诉求是:
  • 技术沉淀
  • 视野+平台
 
所以,初创公司便不考虑在自己的范围之内了,我当然也是很想进入互联网大厂了,奈何明白自己还是有差距的,但不试试怎么知道自己究竟差在哪里呢?找到差距,才能快速提升,对吧?
 
面试的公司:
阿里、网易、滴滴、百度、字节、饿了么、携程、喜马拉雅
 
有的结果不理想,但是也算是是检测了一下自己,查缺补漏,以此督促自己加强学习。

02

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

请你分析一下,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 其实是 promise 的升级版,但它的逻辑和理解却要比 promise 复杂。因此,程序员们在上面要花费一些学习成本,所以我个人不推荐大家使用generator。

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

03

其实,对于我们这些 1-3 年工作经历的前端,如何才能在面试时中脱颖而出呢?


踏实的基本功,加上丰富的实战经验,技术栈也不要给自己设限,React、Vue,、客户端开发、Node、Canvas ... 撸起袖子就是干,同时对于目前紧迫的业务涉及的技术也需要深入了解,看学习视频,多多投资自己。


因此,对于开发人员来说,技术一定得跟业务并进,那么怎样提升呢?


说到这,我真诚的给你推荐拉勾教育的课程了,大家知道,拉勾深耕招聘领域多年,在“人岗匹配”的过程中,发现很多人才的知识能力体系与企业的用人需求存在偏差。为了解决这个问题,拉勾教育团队历经 12 个月的精心打磨,推出《大前端高薪训练营》

 


 

 
现在扫码,即可免费获取  Web 前端资料
(涵盖技能图谱+源码+面试题+学习资料)

为什么要推荐《大前端高薪训练营》?

 

真内推·真就业
大家应该了解,拉勾深耕互联网招聘多年,打通了「人才培养+人才输送 的闭环」,学完后,直接帮你内推到对口的大公司,相当于为企业定向招聘,从学习到就业一条龙服务,帮助互联网人快速成长,实现升职加薪。

一道阿里/字节真题理解前端异步编程
 
目前,拉勾教育毕业学员   成实现涨薪,最高涨幅达 215% ,就业企业不乏阿里巴巴、 腾讯、百度、字节跳动、美团、京东等明星企业.

 

真实战·真项目

拉勾教育的《大前端高薪训练营》课程设计对标阿里 P7,覆盖主流前端技术知识,真正从市场需求、商业价值角度出发进行研发,掌握“大厂”最新的开发技能:

一道阿里/字节真题理解前端异步编程

权威商业实战项目剖析,带你深入到大型互联网项目实战中,涵盖了当下最火热的项目:在线教育、电商门户、B端系统。

一道阿里/字节真题理解前端异步编程

针对常见业务和技术问题,拉勾提供了全套解决方案,帮你轻松应对技术难题。

真保障·真服务

拉勾是一个互联网招聘平台,所以,拉勾网和各大互联网企业,都有深入的合作关系。目前的企业资源,是 98 万+。

 

课程仅仅是开始,接下来还会帮你优化简历,模拟面试,最后内推到大厂,做到真正的一条龙服务!


免费送大厂资料,手慢无!
我们整理了一个【Web 前端资料】大礼包,对于想了解行业情况的,免费赠送!



 

 
现在扫码,即可免费获取  Web 前端资料
(涵盖技能图谱+源码+面试题+学习资料)

常见问题

 

什么样的基础适合学习这门课程?

  1. 技术基础薄弱:只懂应用,不懂底层原理,知其然并不知其所以然,一旦遇到复杂问题就无从下手

  2. 自我提升困难:无法建立整体的知识体系,缺少系统化的学习和提升,短期无法提高

  3. 项目经验单一:长期从事技术重复工作,对高阶技能等缺乏实战经验,职业发展受限制

  4. 进大厂无通道:现有的能力和经验不足以受到大厂的青睐,也没有猎头愿意帮忙内推到大厂

 
拉勾教育《大前端高薪训练营》区别于其他平台的优势?
  1. 覆盖 200+ 主流技术点,提供晋升阿里 P7 的完整路径,体系化夯实技术实力;
  2. 100% 还原多个公司的真前端项目,快速积累 Web、小程序、App 等反客户端领域实战经验;
  3. 夯实语言底层基础,8 大阶段逐步打造前端核心竞争力,告别野路子;
  4. 提供 20+ 商业级前端技术解决方案,轻松应对更多更难的业务问题,学来即用;
  5. 直击面试重点难点,优秀学员可享每月大厂内推机会。

 

 

点击“阅读原文”即可参与

以上是关于一道阿里/字节真题理解前端异步编程的主要内容,如果未能解决你的问题,请参考以下文章

《深入理解ES6》笔记—— Promise与异步编程

大前端进击之路|JavaScript异步编程

理解js异步编程

阿里字节offer收割系列:数据倾斜!(面试真题,建议收藏)

阿里字节offer收割系列:数据倾斜!(面试真题,建议收藏)

理解Javascript的异步