字节前端校招一二三(三面挂)

3月8日一二面。

一面:

开始问:学过操作系统,计网,数据结构吗?答:只学过数据结构。(其他两个我有看过书,但保险起见我还是只回答了这一个)
1.进程和线程的概念?进程间通信方式?并发与并行的区别?如果两个线程都访问同一个内存的话,该怎么做呢?
2.tcp与udp的区别?三次握手详细过程以及每一阶段的状态?为什么需要三次?tcp可靠传输的保证?如何区分一个数据报是本次连接产生的还是上一次由于网络拥塞延迟到达的?
3.js数据类型?symbol的应用?判断数据类型的方式?typeof null,[],undefined返回值?instanceOf检测原理?实现instanceOf
4.为啥要提出BigInt数据类型,js中数的表示规范,说具体。
5.js闭包?应用、坏处。
6.js垃圾回收机制,算法。
7.说一说事件循环,然后代码看输出
8.html标签的常用属性?答id,class。寻找dom节点的api?byid,byclassname,queryselector的区别?
9.css的position属性有哪些,具体说说。
10.听说过样式标准化吗?不太了解。各个浏览器的默认样式有区别吗?
11.从一个包含学生成绩数组的中找到成绩第k好的所有学生的id,学生信息如下:[{score:89,id:1},{score:23,id:4}]。
利用计数排序思想,我的代码可能有点瑕疵,成绩好像反了。说说时间、空间复杂度。
12.说说快速排序原理。时间、空间复杂度。
反问:我还有那些地方需要加强,回答说段时间了解的不多,也没啥好的建议,在js方面可以加强。
一面结束后在房间等了几分钟二面来了。

二面:

1.算法两数之和。

叙述原理,时间、空间复杂度。
2.算法最长无重复字符,要求返回具体的字符串。叙述原理,时间,空间复杂度。

3.学习vue多久了?说说v-model,怎么在组件上使用?是什么的语法糖?
4.vue如何监听数据改变。watch,computed,怎么监听深层次的对象。
5.v-if和v-show的区别,使用场景。
6.叙述重排和重绘
7.怎么学习前端的。怎么学习一个新的技术点。
8.script标签的defer和async的区别?多个标签有同一属性时顺序是怎样的,能保证有序吗?
二面结束后问我有时间吗,我愣了一下,然后面试官说如果有接下来的面试是接着面还是换时间,我说如果有的话就换时间。因为我当天11点开面,1点才结束,早饭和中饭都没吃。当天下午hr打电话约了10号三面。

三面:3月10日

面试官是个中年人,挺严肃的,问我有实习经验吗?答:没有,于是开始做题。
(下面的代码我只截了函数里面的部分,声明那些没截,return语句也没截)
1.实现字符串的trim方法。挂在字符的原型链上

2.实现一个深拷贝。调用deepCopy(target)
4.实现模板字符串。
function template(pattern,data) {
  let len=pattern.length;
  let res = []
  for(let i=0;i<len;i++) {
    if(pattern[i]==='$') {
      if(pattern[i+1]!=='{') continue;
      let t=i;
      while(pattern[i]!=='}') {
        i++;
      }
      let tmp = pattern.slice(t+2,i);
      res.push(data[tmp]);
    }
  }
  let result=''
  for(let m=0;m<len;m++) {
    if(pattern[m]!=='$') {
      result+=pattern[m];
    } else {
      while(pattern[m]!=='}') {
        m++;
      }
      result+=res.shift();
    }
  }
  console.log(result)
  return result;
}

template("${name} is  ${age} years old",{name:"Jim",age:20});
template('asdd ${tgy}  has ${gender}',{tgy:'tgy',gender:'man'})
5.返回二叉搜索树第k个数字。(树的定义和建树我就不再写了)
const InoderTravse = (root,k)=> {
  //let res = [];
  let result = -1;
  const travel =(node)=> {
    if(!node) return;
    travel(node.left);
    k--;
    if(k===0) {result=node.val}
    //res.push(node.val);
    travel(node.right);
  }
  travel(root);
  console.log(result);
  //return res[k-1]?res[k-1]:-1;
}

InoderTravse(tree,1);
InoderTravse(tree,2);
InoderTravse(tree,3);
一开是我是用res来存储节点,让我优化空间,于是就是上面的。
6.代码看输出并解释。(这道题答错了,我规则记忆有点错乱了)
if ([] == false) {console.log(1);};

if ({} == false ) {console.log(2);};

if ([]) {console.log(3);};

if ([1] == [1]) {console.log(4);};
7.js闭包。
8.当声明一个变量时,会存在一个虚拟地址和物理地址,为什么要这样设计,你可以从c/c++方面解释。(这道题我不懂,就说了一个应该是为了余弦为变量分配内存空间吧。)
9.osi七层模型及对应功能。
10.前端跨域方案。
最后说说自己的优缺点,怎么改正缺点,问手上有没有其他offer,答没有。
反问:对我的建议。答:沟通方面可以加强,js加强,多看一些项目,或者实习。(听到这我知道多半凉了,毕竟我是来校招的)。

结语:

今天联系了我的内推人查了一下进度,过了一会老哥跟我说跟hr确认过了的确是三面挂了。
心情异常低落,这是我第二家公司挂在三面了,还有其他不同的公司挂,我已经没有信心了,你们加油吧。毕业季的很多事一涌而来,我的压力好大,无处释放。
大家看了了解一下就行了,也别问我问题了,我就不回复任何人了,就这样吧。拜拜。
#字节跳动##面经##校招##前端工程师#
全部评论
老哥,你这面试好难啊
3 回复 分享
发布于 2021-03-12 13:49
已经很强了,心态稳住
1 回复 分享
发布于 2021-03-13 11:15
校招确实比实习难好多呀。
1 回复 分享
发布于 2021-03-12 21:00
可以问下是什么部门么?
1 回复 分享
发布于 2021-03-12 13:54
别急呀bro,我面了很多公司,一面都没过去,我都没见过二面的脸,所以你已经很出色了,就差那么一点点运气,我们再学一学,说不定就成了
点赞 回复 分享
发布于 2021-06-07 17:34
已经很厉害了加油
点赞 回复 分享
发布于 2021-03-18 21:06
发个娱乐版模板字符串 function template(pattern, data) {   return new Function(     `with(${JSON.stringify(data)}) { return \`${pattern}\` }`   )() }
点赞 回复 分享
发布于 2021-03-16 11:42
function template(pattern, data) {   return pattern.replace(/\$\{(\w+)\}/g, function (match, prop, offset, string) {     return data[prop] ?? ''   }) }
点赞 回复 分享
发布于 2021-03-15 10:30
已经很优秀了,换我一个算法也做不出来
点赞 回复 分享
发布于 2021-03-13 01:41
借楼,北京地平线机器人招聘暑假实习生,cv算法开发
点赞 回复 分享
发布于 2021-03-13 00:17
加油继续努力~(需要飞书内推的可以私信我~前端岗进入面试流程可以提供面试指导)
点赞 回复 分享
发布于 2021-03-12 23:07
老哥加油,很厉害了
点赞 回复 分享
发布于 2021-03-12 21:59
觉得你很棒
点赞 回复 分享
发布于 2021-03-12 20:41
加油,老哥
点赞 回复 分享
发布于 2021-03-12 20:31
老哥,加油!!!
点赞 回复 分享
发布于 2021-03-12 20:12
大佬,你已经很强了!
点赞 回复 分享
发布于 2021-03-12 18:44
这也太难了吧。同问是什么部门
点赞 回复 分享
发布于 2021-03-12 15:31
function getTemplate( pattern , data ){     let str = ""     let stack = []     for( let key of pattern ){         if( key === "{" ){             stack.push( str )             str = ""         }else if( key === "}" ){             const _data = stack.pop()             const result = data[str]             str = _data + result         }else if( key === "$" ){             continue         }else{             str += key          }     }     return str } 算法还得继续加强,加油
点赞 回复 分享
发布于 2021-03-12 15:04
老哥加油,不着急,后面慢慢来
点赞 回复 分享
发布于 2021-03-12 13:38

相关推荐

2025-11-08 22:19
浙江科技大学 运营
Java转测开第一人:这种就是饼 把应届当廉价劳动力用完然后丢掉
你觉得今年秋招难吗
点赞 评论 收藏
分享
2025-12-24 15:25
已编辑
门头沟学院 前端工程师
是腾讯的csig腾讯云,前天晚上九点突然打电话约面,激动的通宵学了一晚上,第二天状态很差改了今天(以后再也不通宵学习了)感觉自己浪费了面试官一个半小时单纯手写+场景,无八股无项目无算法,打击真的很大,全是在面试官提醒的情况下完成的,自己技术方面真的还是有待提高,实力匹配不上大厂和已经面试的两个公司完全不一样,很注重编码能力和解决问题的能力,然而我这两个方面都很薄弱,面试官人很好很耐心的等我写完题目,遇到瓶颈也会提醒我,写不出题也会很耐心的跟我讲解好感动,到最后面试结束还安慰我打算把下周最后一场面试面完之后就不面啦,如果能去实习还是很开心,但是最重要的还是好好努力提高技术以下是面经第一题//&nbsp;实现一个解析&nbsp;url&nbsp;参数的函数function&nbsp;parseUrl(urlStr)&nbsp;{//&nbsp;TODO}parseUrl('*********************************************');//&nbsp;返回&nbsp;{a:&nbsp;1,&nbsp;b:&nbsp;2,&nbsp;c:&nbsp;3}追问:在链接里见过什么部分?用&nbsp;hash&nbsp;路由的话放在哪第二题//&nbsp;考虑有一个异步任务要执行,返回&nbsp;Promise,这个任务可能会失败,请实现&nbsp;retry&nbsp;方法,返回新方法,可以在失败后自动重试指定的次数。/***&nbsp;异步任务重试*&nbsp;@param&nbsp;task&nbsp;要执行的异步任务*&nbsp;@param&nbsp;times&nbsp;需要重试的次数,默认为&nbsp;3&nbsp;次*/function&nbsp;retry(task,&nbsp;times&nbsp;=&nbsp;3)&nbsp;{//&nbsp;TODO:&nbsp;请实现}//&nbsp;---------------测试示例&nbsp;----------------//&nbsp;原方法const&nbsp;request&nbsp;=&nbsp;async&nbsp;(data)&nbsp;=&gt;&nbsp;{//&nbsp;模拟失败if&nbsp;(Math.random()&nbsp;&lt;&nbsp;0.7)&nbsp;{throw&nbsp;new&nbsp;Error('request&nbsp;failed');}const&nbsp;res&nbsp;=&nbsp;await&nbsp;fetch(&#39;https://jsonplaceholder.typicode.com/posts&#39;,&nbsp;{method:&nbsp;'POST',body:&nbsp;JSON.stringify(data),});return&nbsp;res.json();}//&nbsp;新的方法const&nbsp;requestWithRetry&nbsp;=&nbsp;retry(request);//&nbsp;使用async&nbsp;function&nbsp;run()&nbsp;{const&nbsp;res&nbsp;=&nbsp;await&nbsp;requestWithRetry({&nbsp;body:&nbsp;'content'&nbsp;});console.log(res);}run();第三题就是给&nbsp;retry&nbsp;函数添加类型注释,用到泛型第四题:在组件库中将&nbsp;Alert&nbsp;用&nbsp;api&nbsp;的形式实现(应该就是&nbsp;message&nbsp;这个组件)怎么渲染到一个浮层里而不是原地渲染出来
不知道怎么取名字_:技术这个东西,太杂了,而且要下功夫的
查看5道真题和解析
点赞 评论 收藏
分享
评论
14
92
分享

创作者周榜

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