最后
经过日积月累, 以下是小编归纳整理的深入了解Java虚拟机文档,希望可以帮助大家过关斩将顺利通过面试。
由于整个文档比较全面,内容比较多,篇幅不允许,下面以截图方式展示 。
由于篇幅限制,文档的详解资料太全面,细节内容太多,所以只把部分知识点截图出来粗略的介绍,每个小节点里面都有更细化的内容!
-
Java 的 Object 类有哪些常用的方法?
-
Java 容器有哪些?哪些是同步容器,哪些是并发容器?
-
ArrayList 和 LinkedList 的插入和访问的时间复杂度?
-
java 反射原理, 注解原理?
-
新生代分为几个区?使用什么算法进行垃圾回收?为什么使用这个算法?
-
HashMap 在什么情况下会扩容,或者有哪些操作会导致扩容?
-
HashMap 检测到 hash 冲突后,将元素插入在链表的末尾还是开头?
-
1.8 还采用了红黑树,讲讲红黑树的特性,为什么大家一定要用红黑树而不是 AVL、B 树之类的?
-
哪些场景下,子类需要重写 equals 方法和 hashCode 方法?
-
Java 异常,什么是 checked Exception 和 unchecked Exception,举几个具体的例子;是否研究过 Spring Boot 中的异常;
-
ConcurrentHashMap 的特性和实现原理;
-
什么是分库分表,以及分库分表的具体方法和使用场景;
-
数据库事务的 ACID;
-
什么是分布式锁以及其实现原理和使用场景;
-
幂等性问题。
这里需要说一下,上面的面试题其实都很基础,尤其是涉及到 Java 本身的如果你是从事 Java 开发的,但是只局限于应付公司的业务代码,从来没有主动去研读一下 jdk 的一些常用类库,无论从应付面试来说,还是就你的 Java 技术栈的提高乃至技术职业生涯都是不好的,希望从事 Java 开发的读者要意识到这一点。
网络上有很多类似于 Java 面试高频知识点总结的帖子和课程,我个人觉得这些课程你可以用它作为大纲,但是千万不能只达到这些大纲要求的深度,作为 Java 开发者,jdk 的源码,尤其是常用的 java 类的源码还是建议认真阅读一下。
第一轮技术面试结束后,我就问面试官是否通过了。面试官告诉我通过了,然后我问他下一轮的的面试会安排在什么时候。我当时告诉他希望他们尽快安排,已经有其他的公司在催我入职了。面试官说去沟通一下。
于是当天下午大概一两点左右,一面面试官问我晚上是否有时间,给我安排第二轮技术面试,于是约了当天晚上七点。
第二轮技术面试
-
查询中哪些情况不会使用索引?
-
数据库索引,底层是怎样实现的,为什么要用 B 树索引?
-
Mysql 主从同步的实现原理?
-
MySQL 是怎么用 B+树?
-
谈谈数据库乐观锁与悲观锁?
-
有使用过哪些 NoSQL 数据库?MongoDB 和 Redis 适用哪些场景?
-
描述分布式事务之 TCC 服务设计?
-
Redis 和 memcache 有什么区别?Redis 为什么比 memcache 有优势?
-
Redis 的数据结构
-
海量数据过滤,黑名单过滤一个 url。
-
讲一讲 AtomicInteger,为什么要用 CAS 而不是 synchronized?
第二轮技术面试是主管面试。原来约了晚上七点,我到了之后一面的面试官接待了我,并告知我他们主管临时有点急事,能不能把时间改到九点,或者再约。我当时想来了就来了,就不单独约时间了。于是在这之前和一面的面试官又聊了一下,一面的面试官人很 nice,我们聊了很多东西
聊了大概一个多小时后,结束了面试,我离开时,发现外面的沙发上还有一个人等待面试,汗,竞争压力真大。
第二天早上,我通过一面面试官帮我打听二面面试结果,大概中午的时候,二面面试官加我微信说面试通过了,但是三面面试官,也就是他们大部门的 leader 在深圳出差,问我是否方便视频面试,我说可以,于是就约定了第二天晚上七点的视频面试。
第三轮技术面试
-
考虑 redis 的时候,有没有考虑容量?大概数据量会有多少?
-
Redis 的 list zset 的底层实现
-
集群监控的时候,重点需要关注哪些技术指标?这些指标如何优化?
-
从千万的数据到亿级的数据,会面临哪些技术挑战?你的技术解决思路?
-
数据库分库分表需要怎样来实现?
总结
三个工作日收到了offer,头条面试体验还是很棒的,这次的头条面试好像每面技术都问了我算法,然后就是中间件、MySQL、Redis、Kafka、网络等等。
- 第一个是算法
关于算法,我觉得最好的是刷题,作死的刷的,多做多练习,加上自己的理解,还是比较容易拿下的。
而且,我貌似是将《算法刷题LeetCode中文版》、《算法的乐趣》大概都过了一遍,尤其是这本
《算法刷题LeetCode中文版》总共有15个章节:编程技巧、线性表、字符串、栈和队列、树、排序、查找、暴力枚举法、广度优先搜索、深度优先搜索、分治法、贪心法、动态规划、图、细节实现题
《算法的乐趣》共有23个章节:
- 第二个是Redis、MySQL、kafka(给大家看下我都有哪些复习笔记)
基本上都是面试真题解析、笔记和学习大纲图,感觉复习也就需要这些吧(个人意见)
- 第三个是网络(给大家看一本我之前得到的《JAVA核心知识整理》包括30个章节分类,这本283页的JAVA核心知识整理还是很不错的,一次性总结了30个分享的大知识点)