金九银十期间成功斩获58万Offer!六面字节跳动面经(成功关键:吃透九大核心知识+狂刷大厂面试真题)
第一轮基本上是你的团队成员面试你,是和你同级或者高你一个P的师兄来面你,我的话基本没问什么特别的,主要还是讲自己简历上的做的项目,这里需要你很熟悉自己的项目才行,我个人觉得这里你要把项目里你的角色做了什么没做什么讲清楚,然后最好能把自己做的那部分重点展开来讲,然后面试官会从你讲的内容里挑一些具体来问你,这部分就因人而异了,知道的说不知道的别瞎说。最后还会问你一些什么TCP/UDP啊、网络模型啊之类的基础知识。我是觉得这一面只要你项目靠谱、不吹牛逼、底子扎实,过一面应该都不是问题。
这一面其实跟第一面差不多,就是你的师兄们筛完简历了,然后到你的主管来面试你了而已。这一面我的面试官还是让我主要介绍简历(可能因为我是社招,有项目经历他们比较感兴趣吧),然后我就又讲了一遍,因为我一面完了之后有思考过,所以这一次基本上上次没有讲到或者讲得不好的地方这次我都有注意,基本讲的还行。然后接下来依旧是根据你讲的东西来挑重点的来问,这部分真的没有什么固定套路,都是他们听见啥感兴趣的就会问你是“怎么实现的,为什么这么实现,有没有更好的实现方式”这三个问题,这一回除了你要对自己项目足够熟悉之外,还要求你对你做过的东西要有思考才行,你要是现想,那肯定是不靠谱的。这一轮对面最少都是P8级别的人了,千万可别不懂装懂的乱说呀。还是那句话,知之为知之,不知为不知,是知也。
这一面基本是找个其他部门和你将来的主管平级的leader来面你一遍,防止前面自己部门面试作弊嘛,基本套路和二面差不多,但是会多问你一些基础知识和编程能力上的事,主要还是以考核你为目的,肯定不是为了难为你的,所以,好好加油表现出你自己就行。
这一面据我后来的师兄讲本来是二面,是想省了的,但是后面由于流程规定,又给我加回来了,所以我就经历了一次在线笔试的面试。这一面的面试是给你一个在线网站,然后你和你的面试官一起登陆上去,共享web页面,然后他给你出题,你来现场写代码,伪代码就行,然后你再给他讲一遍你的逻辑就ok了。这一面没什么好讲的,写代码嘛,是骡子是马拉出来溜溜咯。出的题不会很难,我答的是两道,一道给我半小时,第一道是给你一个shell命令,执行的功能大概就是读取一个日志文件,然后根据日志里的某一字段排序,然后取前五,输出。大概考点就是:
1.你得读懂这个有cat、有awk、有sort等等猛地一看还挺长的shell命令;
2.实现它;
3.时空间复杂度/效率;
4.讲清楚。
第二道题目是反转字符串,大概就是把字符串“123456789”从中间分开,然后分别反转,然后输出,输出结果是“432159876”。大概考点就是:
1.实现它;
2.时空间复杂度/效率;
3.讲清楚;
4.尝试给出优化方案;
大概就是这种类型的题,肯定不会重复的,师兄说很可能就是他们最近写代码遇到的问题,就直接拿来问你了,所以也没什么固定套路,你也不用临时抱佛脚的刷题,随缘就好。
到这一面的时候基本就稳了,当然我也见过挂的。这一面就是你的主管的主管来面你了,我当时还是先讲项目,然后挑重点的问,不过和二三面明显的区别就是他会问你更高层次的解决方案,不再拘泥于你做的那一点东西,会让你从整体上或者部分整体上讲清楚你项目的解决方案以及你自己的思考(上面的那三个问题),会让你尝试给出更好的解决方案,并解释原因。我个人感觉这一面更多的是考验你的全局观,你要是一直拘泥于自己的小天地,那估计会吃亏的。当然,面试分人的,有的非技术出身的主管就是和你聊聊天谈谈人生理想什么的,你要是不match也会被淘汰。
如果你能面到这一面那你基本99%拿到Offer!主要就是和你谈人生、谈理想、谈三观、谈薪资,只要你不反人类、不扯淡,就OK。
把自己的面试经历分享出来之后,很多朋友都问我有没有什么学习方法,其实除了自己的所需要的掌握的技术之外,面试过程中一些技巧和一些面试题也是必不可少的!可以分享给大家一条自己刷的面试题,里面涵盖了:Java基础、JVM、多线程与高并发、spring、springMVC、MyBatis、SpringBoot、SpringCloud、微服务、数据库、网络底层、TCP、数据结构与算法等等以及一整套的大厂面试真题!
这份笔记总共九大部分,涵盖了Java小白到Java架构师层面的面试知识点总结,作者承诺:这份笔记100%免费获取!因为这份笔记的知识点太多,小编没办法为大家全部完整的展示出来。
本篇主要讲述了JVM原理,涉及JVM运行机制、JVM内存模型、常用垃圾回收算法和JVM类加载机制等内容。
本篇讲解Java基础知识,涉及集合、异常分类及处理、反射、注解、内部类、泛型和序列化等内容。
本篇讲述讲解Java并发编程知识,涉及Java多线程的工作原理及应用、Java线程池的工作原理及应用,以及锁、进程调度算法等内容。
本篇讲解数据结构知识,涉及栈、队列、链表、散列表、二叉树、红黑树、图和位图等内容。
本篇讲解Java中的常用算法,涉及二分查找、冒泡排序、插入排序、快速排序、希尔排序、归并排序、桶排序、基数排序等算法。
本篇讲解网络与负载均衡原理,涉及TCP/IP、 HTTP、常用负载均衡算法和LVS原理等内容。
本篇讲解数据库及分布式事务原理,涉及数据库存储引擎、数据库并发操作和锁、数据库分布式事务等内容。
本篇讲解分布式缓存的原理及应用,涉及分布式缓存介绍、Ehcache原理及应用、Redis原理及应用、分布式缓存设计的核心问题等内容。
本篇讲解设计模式,涉及常见的23种经典设计模式。
受限于文章篇幅问题,全部面试的免费获取方式看图!
1. jdk1.7 到 jdk1.8 Map 发生了什么变化(底层)?
2. ConcurrentHashMap
3. 并行跟并发有什么区别?
4. jdk1.7 到 jdk1.8 java 虚拟机发生了什么变化?
5. 如果叫你自己设计一个中间件,你会如何设计?
6. 什么是中间件?
7. ThreadLock 用过没有,说说它的作用?
8. Hashcode()和 equals()和==区别?
9. mysql 数据库中,什么情况下设置了索引但无法使用?
10. mysql 优化会不会,mycat 分库,垂直分库,水平分库?
11. 分布式事务解决方案?
12. sql 语句优化会不会,说出你知道的?
13. mysql 的存储引擎了解过没有?
14. 红黑树原理?
蚂蚁Java 一面
1. 二叉搜索树和平衡二叉树有什么关系,强平衡二叉树( AVL 树)和弱平衡二叉树
(红黑树)有什么区别
2. B 树和 B+ 树的区别,为什么 MySQL 要使用 B+ 树
3. HashMap 如何解决 Hash 冲突
4. epoll 和 poll 的区别,及其应用场景
5. 简述线程池原理, FixedThreadPool 用的阻塞队列是什么?
6. sychronized 和 ReentrantLock 的区别
7. sychronized 的自旋锁、偏向锁、轻量级锁、重量级锁,分别介绍和联系
8. HTTP 有哪些问题,加密算法有哪些,针对不同加密方式可能产生的问题,及其
HTTPS 是如何保证安全传输的
蚂蚁 Java 二面
1. 设计模式有哪些大类,及熟悉其中哪些设计模式
2. volatile 关键字,它是如何保证可见性,有序性
3. Java 的内存结构,堆分为哪几部分,默认年龄多大进入老年代
4. ConcurrentHashMap 如何保证线程安全, jdk1.8 有什么变化
5. 为什么 ConcurrentHashMap 底层为什么要红黑树
6. 如何做的 MySQL 优化
7. 讲一下 oom 以及遇到这种情况怎么处理的,是否使用过日志分析工具
蚂蚁 Java 三面
1. 项目介绍
2. 你们怎么保证 Redis 缓存和数据库的数据一致性?
3. Redis 缓存雪崩?击穿?穿透?
4. 你熟悉哪些消息中间件 ,有做过性能比较?
1 、并发编程三要素?
2 、实现可见性的方法有哪些?
3 、多线程的价值?
4 、创建线程的有哪些方式?
5 、创建线程的三种方式的对比?
6 、线程的状态流转图
7 、 Java 线程具有五种基本状态
8 、什么是线程池?有哪几种创建方式?
9 、四种线程池的创建:
10 、线程池的优点?
11 、常用的并发工具类有哪些?
12 、 CyclicBarrier 和 CountDownLatch 的区别
13 、 synchronized 的作用?
14 、 volatile 关键字的作用
15 、什么是 CAS
16 、 CAS 的问题
17 、什么是 Future ?
18 、什么是 AQS
19 、 AQS 支持两种同步方式:
20 、 ReadWriteLock 是什么
21 、 FutureTask 是什么
22 、 synchronized 和 ReentrantLock 的区别
23 、什么是乐观锁和悲观锁
24 、线程 B 怎么知道线程 A 修改了变量
25 、 synchronized 、 volatile 、 CAS 比较
26 、 sleep 方法和 wait 方法有什么区别 ?
27 、 ThreadLocal 是什么?有什么用?
28 、为什么 wait() 方法和 notify()/notifyAll() 方法要在同步块中被调 用
29 、多线程同步有哪几种方法?
30 、线程的调度策略
31 、 ConcurrentHashMap 的并发度是什么
32 、 Linux 环境下如何查找哪个线程使用 CPU 最长
33 、 Java 死锁以及如何避免?
34 、死锁的原因
35 、怎么唤醒一个阻塞的线程
36 、不可变对象对多线程有什么帮助
37 、什么是多线程的上下文切换
38 、如果你提交任务时,线程池队列已满,这时会发生什么
39 、 Java 中用到的线程调度算法是什么
40 、什么是线程调度器 (Thread Scheduler) 和时间分片 (TimeSlicing) ?
41 、什么是自旋
42 、 Java Concurrency API 中的 Lock 接口 (Lock interface) 是什么?对 比同步它有什么优势?
43 、单例模式的线程安全性
44 、 Semaphore 有什么作用
45 、 Executors 类是什么?
46、线程类的构造方法、静态块是被哪个线程调用的
1. 描述一下 JVM 加载 Class 文件的原理机制 ?
2. 什么是类加载器?
3. 类加载器有哪些?
4. 什么是 tomcat 类加载机制?
5、类加载器双亲委派模型机制?
6. Java 内存分配?
7. Java 堆的结构是什么样子的?
8. 简述各个版本内存区域的变化?
9. 说说各个区域的作用?
10. Java 中会存在内存泄漏吗,简述一下?
11. Java 类加载过程?
12. 什么是 GC? 为什么要有 GC ?
13. 简述一下 Java 垃圾回收机制?
14. 如何判断一个对象是否存活?
15. 垃圾回收的优点和原理,并考虑 2 种回收机制? 基本原理是什么?
16. 深拷贝和浅拷贝?
17. 什么是分布式垃圾回收( DGC)?它是如何工作的?
1. 说说你的⼯作经历?
2. 项⽬主要负责哪⼏个模块?
3. 画出你项⽬的结构图
4. Eureka 是如何进⾏服务注册的?
5. 如果服务宕机或者⽆法访问了,我还去请求该服务, Eureka会怎么处理? 会有什么现象?
6. 谈谈 Eureka 的保护机制
7. Ribbon 的负载均衡是⾯向服务内部还是外部的?
8. Ribbon 如何实现负载均衡的?
9. 如果没有 Eureka ,我能直接通过 Ribbon 进⾏服务请求吗?
10. Hystrix 如何实现熔断?
11. 当服务⽆法访问时,是直接熔断还是降级?
12. 怎么样才会出现熔断?
13. 在 Springcloud中,消费者调⽤提供者的流程是如何的?请画图 springcloud 的⼯作原理
14. Redis 的集群⽅式有哪些?
15. 如果你原来读取的 Redis中的数据,它的数据的结构发⽣了变化,如何在 不改变代码的情况下进⾏处理,使下游业务不受影响?
16. Redis 的持久化⽅式有哪些?说说他们的具体实现、
17. 使⽤ Redis 的过程中有没有遇到什么问题?
18. Redis 的内存回收机制有哪些?
19. Redis 的过期策略有哪些?简单介绍下不同策略
20. 说说 Redis 的淘汰策略?淘汰的算法可以修改或者⾃⼰重写吗?
21. 你们的项⽬中消息中间件⽤的是什么?
22. 你们的 Rabbit 集群是怎么部署的?
23. Rabbit 集群之间的数据是如何同步的?同步⽅式还是异步⽅式?
24. ⼀个队列中的数据你们是存放在⼀台机⼦上还是多台机⼦上?为什么?
25. RabbitMQ 内部结构是怎么样的?请画出 RabbitMQ 的架构图
26. 你们公司的数据库有分库分表吗?如何实现的?
27. Mysql 的索引是基于什么?
28. 说说 B+ 树
29. 使⽤⾃增 ID 和 UUID 作为主键有什么不同?
30. 说说数据库的事务隔离级别有哪些?
31. 在代码中,我们如何实现事务?
32. 如果在⼀个事务中,代码业务流程很⻓,会有什么问题吗?为什么会出 现这种问题?
33. 使⽤ volatile关键字的时候有遇到过什么问题吗?为什么会出现这种问 题?
34. 请说说 volatile 的底层实现原理
35. 如何创建线程池?有什么参数?线程池的实现原理
36. 你有什么问题想问我们的吗?
1.bio 与 nio 的区别
2.select 与 poll 的区别
3.zookeeper 的⼯作原理
4.cap 理论
5. ⼆段式满⾜ cap 理论的哪两个理论
6. 线程池的参数配置,为什么 java 官⽅提供⼯⼚⽅法给线程池
7. 分布式框架 dubbo 的好处,不⽤ dubbo 可不可以。为什么要使⽤分布式
8. 七个垃圾回收器之间如何搭配使⽤
9. 接⼝限流⽅案
10.ConcurrentHashMap 使⽤原理
11. 解决 map 的并发问题⽅案
12. 什么是协程,以及实现要点
13.lru cache 使⽤ hash map 的实现(算法)
14. 图的深度遍历和⼴度遍历(算法)
15. 基本排序(算法)
16. 设计模式的使⽤
17.java 8 流式使⽤
18. 说说 b+ 树?
19. 内存屏障与 volatile :
20.java 域的概念
21. 分布式设计领域的概念
22. 如何实现双 11 的购物限流( redis 实现⽅案)
23.mysql 调优
24.cdn (异地多活)
25. 进程之间的通信⽅式
26.tcp/ip 协议、 http 协议
27. 写⼀个 redis 分布式锁:
28.spring 7 种事务的传播⾏为:
29. 分布式下 down 机的处理⽅案(⼼跳检测)
30 、分析下分布式强⼀致性、弱⼀致性、最终⼀致性?
31 、 dubbo 与 zookeeper 两者作为注册中⼼的区别,假如注册中⼼挂了,消费者还能调⽤服务吗,⽤什么调⽤的
32 、 dubbo 的原理图(画出注册中⼼,消费者,⽣产者的关系图,并说出每个⻆⾊的作⽤)
33 、项⽬中有没有⽤到多线程?
34 、 HashMap 的底层原理(包括底层数据结构,怎么扩容的)
35 、 ConcurrentHashMap 的原理
36 、 分布式锁的实现
37 、分布式 session ,如何保持⼀致
38 、消息中间件都⽤到哪些,他们的区别
1. 我们知道 hashmap 线程不安全,那⽤什么类可以代替它保证线程安全呢?他们⼜是如何实现线程安全的呢?
2. 说说⼏种 GC 机制?
3. 说说⼀致性 hash ?
4. mybatis 基础知识;
5. mysql 基础知识;
6. mysql 单表达到多少数据量需要分库分表?
7. hibernate 基础知识。
8. 说说 kafka 的原理,为什么能保证这么⾼的吞吐量?
9. 对 webservice 有什么了解?
10. 说说你们公司 git 分⽀管理⽅案?
11. mysql 如何进⾏分表分库?
12. 你们如何和前端进⾏接⼝联调?
13. 说说你平时遇到的重⼤难题或者挑战,以及你解决问题的思路和流程。 平时关注⼀下公司线上问题的解决⽅案。
1. 画出项⽬的架构图
2. 所处⾃⼰负责的业务模块,其中⽤到了哪些技术点?
3. 如何实现最终⼀致性分布式事务?
4. 索引的 B+ 树结构是怎样的?
5. 哪些情况下索引会失效?除了加索引优化查询,还有哪些⽅法?
6. 说说⾃⼰了解的设计模式? Spring中⽤到了哪些设计模式?⾃⼰有⽤过哪些设 计模式吗?
7.TCP 三次握⼿和四次挥⼿机制?
8.Https 原理?
9.Redis 的数据类型有哪些?与 Memcached 的区别?
10. 消息队列有⽤到吗?具体在项⽬中是怎么⽤的?如何保证消息的可靠传递?
1. 说说 java 集合,每个集合下⾯有哪些实现类,及其数据结构?
2. 介绍⼀下红⿊树、⼆叉平衡树。
3. jdk1.8中ConcurrentHashMap size ⼤于 8时会转化成红⿊树,请问有什么 作⽤,如果通过 remove 操作, size ⼩于 8 了,会发⽣什么?
4. 说说 java 同步机制, java 有哪些锁,每个锁的特性?
5. 说说 volatile 如何保证可⻅性,从 cpu 层⾯分析。
6. spring 加载 bean 的顺序?
7. 哪些对象会被存放到⽼年代?
8. 什么时候触发full gc?
9. jvm 中哪些地⽅会出现 oom ?分别说说 oom 的可能原因?
10. 我们如何发现 oom 来⾃ jvm 中哪个区域?
11. 有没有 jvm 调优经验?调优⽅案有哪些?
12. 平时有没有看过什么源码,请画出来。
13. 有没有写过或者看过 custom classloader ?
14. 介绍你最近做的⼀个项⽬,画出框架图并分析业务流程。
15. 平时看过哪些书?
1. 简历写什么问什么,注意所⽤技术产品的同类产品⽣态及对⽐。
2.kafka 数据分区和消费者的关系, kafka 的数据 offset 读取流程, kafka 内部如何保证顺序,结合外部组件如何保证消费者的顺序
3.cms 垃圾回收机制
4.springcloud 各个组件功能,内部细节,与 dubbo 区别, dubbo 架构, dubbo 负载策略
5.mapreduce 原理
6.nio , bio , sellector/epoll , aio , netty ⾃带编解码器, netty 优势, java 内存模型
7.akka 模型
8.java arraylist , linkedlist 区分及实现原理, hashmap 和 concurrenthashmap 区分及实现原理, concurrenthashmap 1.7 和 1.8 区分,
实现细节, linkedhashmap 排序原理,应⽤如何保证数据幂等
9.web.xml listener , filter , servlet 加载顺序。如何不再 web , xml中配置来加载 filter
10. ⽆穷数就 top K 问题,提供多个⽅案
11.a , b , c 三张表,做关联查询,如何优化,可做外键,只在 c 表加 a 表外键即可。
12.CourrentHashMap JDK1.7 和 JDK1.8 有什么区别?
13. 线程 a , b , c , d 运⾏任务,怎么保证当 a , b , c 线程执⾏完再执⾏ d 线程 ?
14. 分布式系统中如何保证数据的⼀致性?
15. 拆分微服务应该注意哪些地⽅,如何拆分?
16.SpringCloud 全家桶包含哪些组件?
17. 有没了解 Docker , Docker 和虚拟机有什么区别?
18. 同⼀个宿主机中多个 Docker 容器之间如何通信?多个宿主机中 Docker 容器之间如何通信?
19. ⾼并发系统如何做性能优化?如何防⽌库存超卖?
20. 如何保证服务幂等性?
免费获取方式:点赞这篇文章+关注我,然后添加小助理即可免费获取!