字节4.8前端三面

自我介绍
有挑战的项目(听了之后觉得没什么好聊的就跳过了)
vite的原理
vite有什么特点
如果要实现一个axios库你会怎么实现
vuex的mutation为什么不能处理异步任务
手撕最大并行异步任务(我感觉写出来可能要很久,就说说思路)

/* 
标题
并发请求限制

题目描述
【背景】​
一般浏览器会限制并发请求数,微信小程序之前也限制过最多请求不超过10个。​
现在,让我们来实现一下这个功能。​
【问题描述】​
实现这样一个函数scheduler,函数入参为并发最大次数。​
如下最终输出顺序: 2、3、 1、 4​
一开始,1、2两个任务进入队列​
500ms时,2完成,输出2,任务3进队​
800ms时,3完成,输出3,任务4进队​
1000ms时,1完成,输出1​
1200ms时,4完成,输出4​
*/
// -----------------mock一些请求​
const request1 = () =>​
  new Promise((resolve, reject) => {
    setTimeout(() => {
      resolve(1);
    }, 1000);
  });

const request2 = () =>​
  new Promise((resolve, reject) => {
    setTimeout(() => {
      resolve(2);
    }, 500);
  });
const request3 = () =>​
  new Promise((resolve, reject) => {
    setTimeout(() => {
      resolve(3);
    }, 300);
  });
const request4 = () =>​
  new Promise((resolve, reject) => {
    setTimeout(() => {
      resolve(4);
    }, 400);
  });
// -----------------最多并发2个请求​
function scheduler(max) {
  // ------你的代码​
}​

const addRequest = scheduler(2);
addRequest(request1).then(res => {
  console.log(res);
});
addRequest(request2).then(res => {
  console.log(res);
});
addRequest(request3).then(res => {
  console.log(res);
});
addRequest(request4).then(res => {
  console.log(res);
}); 

自己的写法和参考牛友绿豆沙的做法(async/await写法),写了以下解答:

function scheduler(max) {
  // 最大并行数为 10
  max = max > 10 ? 10 : max;

  // 用 async/await 语法实现不定数量异步任务串行执行
  let count = 0;
  const queue = [];
  async function _addReq(reqf) {
    count >= max
      ? await new Promise((resolve, reject) => {
          queue.push(resolve);
        })
      : "";

    count++;
    const result = await reqf();
    count--;
    if (queue.length) {
      queue.shift()();
    }

    return result;
  }

  return _addReq;

  // 构造 promise 链实现不定数量异步任务串行执行
  // const path = [];
  // const queue = [];
  // function _addReq(reqf) {
  //   return new Promise((resolve, reject) => {
  //     if (path.length < max) {
  //       path.push(
  //         reqf().then((res) => {
  //           resolve(res);
  //         })
  //       );
  //     } else {
  //       queue.push(reqf);
  //       for (let i = 0; i < path.length; i++) {
  //         path[i] = path[i].then(() => {
  //           if (queue.length) {
  //             const rf = queue.shift();
  //             return rf().then((res) => {
  //               resolve(res);
  //             });
  //           }
  //           return;
  //         });
  //       }
  //     }
  //   });
  // }

  // return _addReq;
}

手撕股票买卖问题,是leetcode121和122,先让你通过一次买卖找出最大利润,再让你通过不限买卖次数找出最大利润(没写出来)

最后事件差不多了,面试官直接跟我说很遗憾我没能写出最后两道题(淦呐,直接告诉我我不过是吧)

最后反问问了一下面试官对低代码这个东西的看法,然后就下线了

心累,倒在了算法题上

#字节跳动##春招##面经##前端#
全部评论
最大并行任务的代码里面,  queue.push(resolve);  这句什么意思。干了两大碗米饭都没想通
点赞 回复 分享
发布于 2022-05-16 15:51
楼主这道并发控制后期有思路吗qeq想了好久没做出来
点赞 回复 分享
发布于 2022-05-08 12:34
手撕最大并行异步任务,是类似用promise实现一个 并发控制器吗? 同时最多只有limit个任务在执行这种
点赞 回复 分享
发布于 2022-04-21 15:41
同面电商业务,异步任务调度器没写出来,三面挂😂
点赞 回复 分享
发布于 2022-04-15 16:22
股票买卖问题是什么难度级别的。该不会是hard吧😂
点赞 回复 分享
发布于 2022-04-10 15:30
过了吗
点赞 回复 分享
发布于 2022-04-10 14:51
老哥投的哪个部门
点赞 回复 分享
发布于 2022-04-09 01:22
老哥base哪里的。什么部门啊
点赞 回复 分享
发布于 2022-04-08 20:55

相关推荐

刚刷到字节跳动官方发的消息,确实被这波阵仗吓了一跳。在大家还在纠结今年行情是不是又“寒冬”的时候,字节直接甩出了史上规模最大的转正实习计划——ByteIntern。咱们直接看几个最硬的数,别被花里胡哨的宣传词绕晕了。首先是“量大”。全球招7000多人是什么概念?这几乎是把很多中型互联网公司的总人数都给招进来了。最关键的是,这次的资源分配非常精准:研发岗给了4800多个Offer,占比直接超过六成。说白了,字节今年还是要死磕技术,尤其是产品和AI领域,这对于咱们写代码的同学来说,绝对是今年最厚的一块肥肉。其次是大家最关心的“转正率”。官方直接白纸黑字写了:整体转正率超过50%。这意味着只要你进去了,不划水、正常干,每两个人里就有一个能直接拿校招Offer。对于2027届(2026年9月到2027年8月毕业)的同学来说,这不仅是实习,这简直就是通往大厂的快捷通道。不过,我也得泼盆冷水。坑位多,不代表门槛低。字节的实习面试出了名的爱考算法和工程实操,尤其是今年重点倾斜AI方向,如果你简历里有和AI相关的项目,优势还是有的。而且,转正率50%也意味着剩下那50%的人是陪跑的,进去之后的考核压力肯定不小。一句话总结:&nbsp;27届的兄弟们,别犹豫了。今年字节这是铁了心要抢提前批的人才,现在投递就是占坑。与其等到明年秋招去千军万马挤独木桥,不如现在进去先占个工位,把转正名额攥在手里。
喵_coding:别逗了 50%转正率 仔细想想 就是转正与不转正
哪些公司开暑期实习了?
点赞 评论 收藏
分享
评论
8
30
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务