字节-一面+二面凉经
之前面了几家小厂,感觉一般。又加上字节约面,虽然知道字节挺看重面评,但也实在想试试,就面了。12.17一面,12.18二面凉
一面
自我介绍+介绍项目
视频播放记录的hash结构、点赞的set的key用的是什么?
记录播放进度的hash设置过期时间了吗?能不能只对某个hashkey设置过期时间。
你的排行榜刷新时间怎么确定的?
为什么redis选择跳表实现zset,而不是红黑树?
你认为mysql建立索引应该根据哪些标准选择字段?
- 一个很长的字符串也满足:区分度高、不常变、经常作为查询条件的特点,为什么很少对这种字段建立索引?
你在修改库存时,一条update会锁住一行记录。那如何应对高并发?
为什么选择rabbitmq作为消息队列?
rabbitmq的消息确认机制?
redisson的分布式锁的结构,过期时间设置,超时续约机制。
领取优惠券:redis中预判成功就返回成功信息吗?你这时候还没落库。要是MQ消费不成功,就落库不了,你还能在后续使用吗?
算法题: lc.岛屿数量,不修改原有元素,借助vis数组。(遍历的一行代码写错了,debug10min才看出来)
反问:建议进一步巩固基础,对校招生更看重基础
二面
自我介绍+介绍项目
你为什么要考虑合并写?mysql的并发量,redis的并发?
你在什么场景下会选择用redis?什么场景用mysql?
对于抖音的播放进度记录(上亿并发),你会怎么设计?
redis的原始命令:对hash、set 的原始操作命令。(好久没用,回答错了)
写了一个连表+子查询
- order(orderId, userid), user(userid, username),需要统计出订单数大于3的orderid,userid,username
explain 如何看先走子查询还是外面的查询?
explain命令的type有哪些类型:主要有:const(唯一索引上单条匹配)、ref(非唯一索引上多条匹配)、range(索引上范围)、index(使用索引遍历全表)、all(全表)
给了一些场景,怎么建立索引,select * from test where a = 1 and b = 1; select * from test where a between(2,5) and b = 1;
算法题:模拟对任务的请求限制,任务具有处理时间,同一时间只能处理两个任务。A(1,1000) B(2,500) C(3,300) D(4,400),输出 2-3-1-4。(这个直接用线程池或者信号量控制并发线程数应该就可以了,但当时没想到,寄)
- 只说了大致思路,进一步提问是否有无锁方案。(内置的线程池算是无锁方案吗)
反问:可能见我答的不咋滴,还安慰我说,每个人的知识面不一样,面试不一定非要全部答出来qwq
总结:继续沉淀吧。
#字节求职进展汇总#