“三无渣本211”校招大厂工作两年多,最后社招四面成功跳槽字节跳动!
作者:互联网
个人背景
博主本科渣211,硕士华科,专业均SE,校招的时候没啥实习经历,进大厂工作两年多,做后端开发的工作,没有涉及到高并发的case,也没有大流量的项目,也没有必须引入某些中间件或者nosql才能解决业务问题的场景,简称“三无”,只能尽量在简历里矮子里面拔将军,写一些可能有些价值点的内容。社招过程中拿过美团、货拉拉、微众、阿里、字节的offer,最终选择字节,所以也只分享字节的面试经验感受。
一面
一面面试老师是个小姑娘,人特别好(不仅仅指长相啊)。
问了mysql的索引
Redis的string类型
为什么使用rabbitmq
rabbitmq有哪些部件,如何保证准确性跟一致性。
算法问了两道
快排
无序数组计算每个位置大于前面的多少个数字(归并排序)
二面
二面就开始偏向项目了,
如何进行jvm调优(然后我巴拉巴拉,老师说你写下具体的参数跟请求命令)
cpu满了重启系统后好了,但是一会又满了,如何具体解决。(老师有点严格,一直说我不要听原理,你给我说具体的命令)
然后问了如何设置秒杀系统
如何设置银行系统,会碰到什么问题
为什么项目中使用了mongodb
同样两个算法
一个文本距离计算
(用动态规划解决)
一个是无序数组可以存储多少雨水问题
三面
没有问技术
就是聊了聊怎么学习的
看了那些书
如何设置一个抢红包的功能
以及自己项目中碰到了哪些问题,如何解决的
项目的技术选型以及为什么要选择它
然后最手写一个算法
实现对hashmap增强,加上过期自动删除还有淘汰策略实现最短过期时间删除
HR面
技术规划
还投了哪些公司
字节了解
为什么考研
项目中最大的收获
获取Java学习笔记,面试文档,电子书PDF,面经资料,面试题目解析:戳这即可100%无偿分享给你!
以下是我刷过的面试题一部分合集,可以查漏补缺下看看自己还有哪些不足~
Java基础
- JAVA 中的几种数据类型是什么,各自占用多少字节。
- String 类能被继承吗,为什么。
- 两个对象的 hashCode() 相同,则 equals() 也一定为 true,对吗?
- String 属于基础的数据类型吗?
- Java 中操作字符串都有哪些类?它们之间有什么区别?
- Java 中 IO 流分为几种?
- BIO、NIO、AIO 有什么区别?
- 用过哪些 Map 类,都有什么区别,HashMap 时线程安全的吗,并发下使用的 Map 是什么,他们的内部原理分别是什么,比如存储方法,hashcode,扩容,默认容量等。
- 如何将字符串反转?
- 抽象类必须要有抽象方法吗?
- 普通类和抽象类有哪些区别?
- 抽象类能使用 final 修饰吗?
- ArrayList 和 LinkedList 有什么区别?
- ConcurrentHashMap的数据结构(必考)
- volatile作用(必考)
- Atomic类如何保证原子性(CAS操作)(必考)
- 为什么要使用线程池(必考)
Redis
- Redis的应用场景
- Redis支持的数据类型(必考)
- zset跳表的数据结构(必考)
- Redis的数据过期策略(必考)
- Redis的LRU过期策略的具体实现
- 如何解决Redis缓存雪崩,缓存穿透问题
- Redis的持久化机制(必考)
- Redis为什么是单线程的?
- 什么是缓存穿透?怎么解决?
- Redis持久化有几种方式?
- Redis为什么这么快?(必考)
- Redis怎么实现分布式锁?
- Redis如何做内存优化?
- Redis淘汰策略有哪些?
- Redis常见的性能问题有哪些?该如何解决?
- Redis的使用要注意什么?
ZooKeeper
- CAP定理
- ZAB协议
- leader选举算法和流程
- zookeeper 是什么?
- zookeeper 有几种部署模式?
- zookeeper 怎么保证主从节点的状态同步?
Mysql
- 事务的基本要素
- 事务隔离级别(必考)
- 如何解决事务的并发问题(脏读,幻读)(必考)
- MVCC多版本并发控制(必考)
- binlog,redolog,undolog都是什么,起什么作用
- InnoDB的行锁/表锁
- myisam和innodb的区别,什么时候选择myisam
- 为什么选择B+树作为索引结构(必考)
- 索引B+树的叶子节点都可以存哪些东西(必考)
- 查询在什么时候不走(预期中的)索引(必考)
- sql如何优化
- explain是如何解析sql的
- order by原理
JVM
- 运行时数据区域(内存模型)(必考)
- 垃圾回收机制(必考)
- 垃圾回收算法(必考)
- Minor GC和Full GC触发条件
- GC中Stop the world(STW)
- 各垃圾回收器的特点及区别
- 双亲委派模型
- JDBC和双亲委派模型关系
- JVM 中一次完整的 GC 流程是什么样子的,对象如何晋升到老年代,说说你知道的几种主要的 JVM 参数
Spring
- Spring的IOC/AOP的实现(必考)
- 动态代理的实现方式(必考)
- Spring如何解决循环依赖(三级缓存)(必考)
- Spring的后置处理器
- Spring的@Transactional如何实现的(必考)
- Spring的事务传播级别
- BeanFactory和ApplicationContext的联系和区别
其他
- 高并发系统的限流如何实现
- 高并发秒杀系统的设计
- 负载均衡如何设计
操作系统篇
- 进程和线程的区别
- 进程同步的几种方式
- 线程间同步的方式
- 什么是缓冲区溢出。有什么危害,其原因是什么
- 进程中有哪几种状态
- 分页和分段有什么区别
多线程篇
- 多线程的几种实现方式,什么是线程安全
- volatile 的原理,作用,能代替锁吗?
- sleep 和 wait 的区别
- sleep(0)的意义
- Lock 和 Synchronized 的区别
- synchronized 的原理是什么,一般用在什么地方(比如加载静态方法和非静态方法的区别)
免费分享Java学习笔记,面试文档,电子书PDF,面经资料,面试题目解析:一键三连后,戳这即可100%无偿分享给你!
写在最后
- 面经不分时间先后,有可能几面几面的没写全,没写完,因为有的面试面经当时忘记记录,所以就忘记了。
- 基本后跟楼主设想差不多,反正前面的都不太好,后面的有了经验可能会好一些
- 另外友情小提示,看准岗位就果断投,很有可能岗位很热,你总想准备的非常好的时候再去面,可能岗位都没了。还有就是大部分的公司都需要算法题的考验,大多来自力扣简单跟中等难度,困难我个人觉得随缘吧。除了最好能ac外,我觉得有些算法思想你要掌握,你如dp怎么玩?回溯怎么玩?递归怎么玩?stack能解决啥问题?fifo能解决啥问题?dfs怎么玩?bfs怎么玩?实在ac不了,谈谈你对算法的思考过程,选用什么数据结构去解决问题?时间复杂度是多少?但个人感觉如果你没刷过这个题目,现场让你20分钟去做,还是很困难的,毕竟考虑到你的紧张,ide的问题,还要思考,敲代码,还要注意时间复杂度什么的。如果一开始就让你做算法题更是。。给你后面的面试问题都带来很大压力。
- 上面写到的算法题如果写在后面 ,那就是最后在做算法题,如果写在前面,就是一开始就要做
寄语
最后祝大家都能拿到心仪的offer,前程似锦.
标签:区别,社招,渣本,什么,211,Redis,必考,如何,算法 来源: https://blog.csdn.net/zx1911269452/article/details/111473769