精选2021互联网大厂Java核心面试题库(春招必看)

  • 回收算法 分别优缺点

  • CMS和G1的区别 分别说一下数据结构

  • CMS和G1分别的使用场景 G1最后一步操作是什么 为什么用户可以自己设置回收内存 jdk这样设计的好处是什么

  • 说一下项目中调优经验

  • 说一下MAT的最长引用链功能 MAT一般用来分析什么比较快

  • 一般你怎么分析一个OOM

  • gc日志里面可以看到垃圾回收器吗

  • 看内存使用情况用什么命令

  • 看程序里面有多少个线程在运行怎么看

  • 线程的状态怎么分析 如果BLOCKING和WAITING状态的线程很多 会出现什么情况 说一下BLOCKING和WAITING的区别

  • 如何排查CPU过高的情况

  • 深堆和浅堆

  • jinfo的作用是什么

  • STW是什么意思 CMS和G1分别在哪些时期发生的STW 有没有可能避免STW的情况

  • 并行和并发的区别

  • 说一下sync锁和lock锁的区别 他们都是为了保证什么 除了这两种方式还可以怎么优雅的保证程序运行正常

  • sync锁的底层原理

  • 为什么轻量级锁就比重量级锁要快

  • 程运行到一半,cpu切换到另一个线程,之后再切换回来执行,是怎么保证在上一次执行点执行的

  • sync锁的锁升级和lock锁的锁降级的区别

  • lock锁的锁降级的优化点是什么,为什么不可以锁升级呢 要是发生了锁升级会导致什么

  • aqs的数据结构 为什么要用single 而不是singalall

  • state变量的作用是什么 用在哪些地方

  • cas是不是一定就比使用sync锁要好 什么情况下用sync锁好一点

  • cas怎么解决的aba问题

  • longadrr原理是什么 是对什么的优化

  • vaolitale为什么不能保证原子性 是怎么导致重排序失效的

  • 线程池原理 参数介绍 平时怎么用的线程池 怎么优雅的监控线程池的关闭

  • 并发工具类有哪些 平时杂用的 原理 区别

  • disruptor的原理 对于阻塞队列优化点在哪 平时杂用的

  • arraynlocingqueqe和linkedbloikingqueue的区别

  • hanppen befor语义 多线程下重排序的问题 解决方法

  • forkjoin思想

  • 设计模式 策略的几种实现 代理uml图 自己项目里面怎么用的 如果一个if else很多的情况下 是不是一定要用策略去改造 这样改造后的优缺点

  • 单例里面的静态内部类的实现

  • 建造者和工厂的区别

  • 继承和内包含的区别

  • spring里面用到设计模式

  • 说下spring你看过的源码流程

  • aop的的通知方法内部执行流程

  • 一个事务中包含多个子事务 怎么解决

  • springboot的spi机制

  • springboot的内嵌tomcat实现原理

  • springboot的自动装配原理

  • mysql的索引原理 有哪些索引 为什么尽量建复合索引 最左侧索引原理 为什么违反就会导致索引失效

  • 索引的数据结构 B+ B树的区别 为啥B+树更快

  • hash索引的场景 是不是都用B+树

  • 如果是一个查询操作很慢你从整体架构到细节怎么排查

  • redis的主从 哨兵 集群分别解决什么问题

  • 主从同步原理 怎么实现的

  • redis可以做哪些事情

  • redis的gossip协议

  • redis的hash算法 一致性hash算法原理

  • 一致性hash算法可以解决负载均衡问题么

  • linux的io模型 indot是什么

  • bio的原理

  • netty项目中的使用 netty中的管道是什么 每条消息的传递原理

  • netty的bytebuf 双指针是什么 零拷贝

  • netty里面怎么解决黏包半包的 tcp滑动窗口是什么 nagle算法 netty

  • 自己实现一个通信协议 尽可能想到完善

  • rpc和http的区别 自己实现一个rpc

  • doss攻击是什么 是怎么钻的漏洞

  • 几种消息中间件的区别 怎么选型 平时项目中用了哪些

  • kafka怎么保证消息不丢失 消息不重复消费 消息有序 消息堆积怎么解决 消息持久化怎么实现的 消息淘汰策略

  • kafka的lsu是什么 保证有序和性能怎么权衡

  • 如果是5个消费者 3个分区 5个消费者都能消费到吗

  • kafka分区在均衡是什么意思 如果我想设置偏移量 怎么设置

  • kafka的副本之间的同步机制

  • 微服务和分布式区别 dubbo用过没有 dubbo的spi dubbo的熔断功能 dubbo支持的一些协议

  • dubbo的整个执行原理 从提供方到消费方的过程

  • springcloud和dubbo的区别 springcloud在项目中怎么用的

  • hystrics原理服务隔离是怎么做的

  • feing的原理

  • 网关统一异常处理是怎么做的 一般你们怎么做的权限 如果是通过网关集成security 前端不加Autchcation 会不会进入网关授权过滤器

  • 画一下你们的架构图数据流,你们系统的伸缩性体现在哪里

  • 一个秒杀场景怎么设计 包括前后端

  • 现在后端日志报了一个事务死锁的bug怎么排查

  • nestat 之后发现有很多wating的进程考虑是什么情况引起的

  • 一个websockt推送的统计数据,程序运行一段时间突然数据不更新了,但是连接还存在,怎么排查,没有任何异常日志

  • 给一个数组找出三个数相加等于数组另一个数的这四个数

  • 树的遍历树图的区别 dfs bfs

  • es的数据结构 倒排索引的原理 es出现中文检索精确度不高的问题

  • es的分词和关键字的区别

  • 分布式锁 分布式事务 cap zab base pacox 2pc 3pc tcc

总结

其他的内容都可以按照路线图里面整理出来的知识点逐一去熟悉,学习,消化,不建议你去看书学习,最好是多看一些视频,把不懂地方反复看,学习了一节视频内容第二天一定要去复习,并总结成思维导图,形成树状知识网络结构,方便日后复习。

这里还有一份很不错的《Java基础核心总结笔记》,特意跟大家分享出来

目录:

部分内容截图:

找小编(vip1024c)领取
分享出来

目录:

[外链图片转存中…(img-YAIAJNpl-1721729747293)]

部分内容截图:

[外链图片转存中…(img-ay0SMrYs-1721729747294)]

[外链图片转存中…(img-rafLMmrz-1721729747295)]

找小编(vip1024c)领取

  • 14
    点赞
  • 17
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值