前言
JVM调优主要是针对垃圾收集器的收集性能优化,令运行在虚拟机上的应用能够使用更少的内存以及延迟获取更大的吞吐量。毫不夸张地说,JVM是现代软件工程最成功的案例之一。因为它自带GC,又有无数可以微调的参数,且运行极其稳定可靠,所以,许多厂商的核心业务系统,才敢放心地用Java编写,运行在JVM之上。
近几年深入学习JVM调优的人越来越多,因为互联网一线大厂的Java高级开发工程师JD中都明确要求了“JVM调优”的能力。JVM调优是跳槽大厂必备的技能,但是由于JVM知识体系过于庞大,非系统学习难以学透,并且即使掌握了全部理论,没有实操,依然无法应对面试!
今天,特将腾讯大佬疯狂加持的“百万级”JVM调优笔记分享给你们,从思维图到优化再到架构,带你轻松上手,一键搞定。
蚂蚁金服
一面
算法题,给了长度为N的有重复元素的数组,要求输出第10大的数。
需要在2小时内完成。
二面
自我介绍
目前在部门做什么,业务简单介绍下,内部有哪些系统,作用和交互过程说下
Dubbo踩过哪些坑,怎么解决的?
对线程安全的理解
乐观锁和悲观锁的区别?
这两种锁在Java和MySQL分别是怎么实现的?
事务有哪些特性?
怎么理解原子性?
HashMap为什么不是线程安全的?
怎么让HashMap变得线程安全?
jdk1.8对ConcurrentHashMap做了哪些优化?
redis主从机制了解么?怎么实现的?
有过GC调优的经历么?
有什么想问的
三面
自我介绍
接下来就是全部问的项目,对自己的项目细节逐个盘问,最后问了下如何改进方案
有什么想问我么?
四面
介绍下自己
问项目
说说Spring的生命周期吧
说说GC的过程
强制young gc会有什么问题?
知道G1么?
回收过程是怎么样的?
你提到的Remember Set底层是怎么实现的?
CMS GC有什么问题?
怎么避免产生浮动垃圾?
有什么想问的么?
五面
HRBP面,主要聊了部门在做的事情、职业发展、福利待遇等。阿里面试官有一票否决权,很看重你的价值观是否match。
HR面一定要诚实,不要说谎,只要你说谎HR都会去证实。
最后HR还对我说目前稳定性保障部挺缺人的,希望我尽快回复。
小结
蚂蚁面试比较重视基础,所以Java那些基本功一定要扎实。
拼多多
一面
聊项目
Java中的HashMap、TreeMap解释下?
TreeMap查询写入的时间复杂度多少?
ConcurrentHashMap怎么实现线程安全的?
HashMap多线程有什么问题?怎么解决?
CAS和synchronize有什么区别?都用synchronize不行么?
get需要加锁么,为什么?
volatile的作用是什么?
给我一张纸,画了一个九方格,都填了数字,给一个MN矩阵,从1开始逆时针打印这MN个数,要求时间复杂度尽可能低,可以先说下思路
有什么想问我的?
二面
自我介绍下
手上还有其他offer么?
部门组织结构是怎样的?
系统有哪些模块,每个模块用了哪些技术,数据怎么流转的?给了我一张纸,我在上面简单画了下系统之间的流转情况
链路追踪的信息是怎么传递的?
SpanId怎么保证唯一性?
RpcContext是在什么维度传递的?
Dubbo的远程调用怎么实现的?
Spring的单例是怎么实现的?
为什么要单独实现一个服务治理框架?
谁主导的?内部还在使用么?
逆向有想过怎么做成通用么?
有什么想问的
HR面
主要问了些职业发展、是否有其他offer、以及入职意向等问题,顺便说了下公司的福利待遇等,手上有其他offer或者大厂经历会有一定加分。
字节跳动
一面
自我介绍
聊项目
Redis熟悉么,了解哪些数据结构? zset底层怎么实现的?
红黑树了解么,时间复杂度?
既然两个数据结构时间复杂度都是O(logN),zset为什么不用红黑树
线程池的线程数怎么确定?
如果是IO操作为主怎么确定?
如果计算型操作又怎么确定?
跳表的查询过程是怎么样的,查询和插入的时间复杂度?
说下Dubbo的原理?
CAS了解么?还了解其他同步机制么?
做题:数组A,2*n个元素,n个奇数、n个偶数,设计一个算法,使得数组奇数下标位置放置的都是奇数,偶数下标位置放置的都是偶数。先说下你的思路
你有什么想问我的?
二面
自我介绍
问项目
分布式追踪的上下文是怎么存储和传递的?
SpringMVC不同用户登录的信息怎么保证线程安全的?
我们聊聊mysql吧,说下索引结构,为什么使用B+树?
Dubbo的RpcContext是怎么传递的?主线程的ThreadLocal怎么传递到线程池?你说的内存泄漏具体是怎么产生的?
线程池的线程是不是必须手动remove才可以回收value?那你说的内存泄漏是指主线程还是线程池?
什么是索引覆盖?
Java为什么要设计双亲委派模型?
什么时候需要自定义类加载器?
做题:手写一个对象池
有什么想问我的
小结
头条的面试确实很专业,而且面试官最后给我了一点建议,就是研究技术的时候一定要结合技术的背景。
面试官都有一个特点,会抓住一个值得深入的点或者你没说清楚的点深入下去直到你把这个点讲清楚,不然面试官会觉得你并没有真正理解。
《一线大厂Java面试真题解析+Java核心总结学习笔记+最新全套讲解视频+实战项目源码》开源
Java优秀开源项目:
-
ali1024.coding.net/public/P7/Java/git
- github.com/spring-projects
最后我们该如何学习?
1、看视频进行系统学习
这几年的Crud经历,让我明白自己真的算是菜鸡中的战斗机,也正因为Crud,导致自己技术比较零散,也不够深入不够系统,所以重新进行学习是很有必要的。我差的是系统知识,差的结构框架和思路,所以通过视频来学习,效果更好,也更全面。关于视频学习,个人可以推荐去B站进行学习,B站上有很多学习视频,唯一的缺点就是免费的容易过时。
另外,我自己也珍藏了好几套视频资料躺在网盘里,有需要的我也可以分享给你:
2、读源码,看实战笔记,学习大神思路
“编程语言是程序员的表达的方式,而架构是程序员对世界的认知”。所以,程序员要想快速认知并学习架构,读源码是必不可少的。阅读源码,是解决问题 + 理解事物,更重要的:看到源码背后的想法;程序员说:读万行源码,行万种实践。
Spring源码深度解析:
Mybatis 3源码深度解析:
Redis学习笔记:
Spring Boot核心技术-笔记:
3、面试前夕,刷题冲刺
面试的前一周时间内,就可以开始刷题冲刺了。请记住,刷题的时候,技术的优先,算法的看些基本的,比如排序等即可,而智力题,除非是校招,否则一般不怎么会问。
关于面试刷题,我个人也准备了一套系统的面试题,帮助你举一反三:
只有技术过硬,在哪儿都不愁就业,“万般带不去,唯有业随身”学习本来就不是在课堂那几年说了算,而是在人生的旅途中不间断的事情。
人生短暂,别稀里糊涂的活一辈子,不要将就。