Java 高级工程师面试高频题:JVM+Redis+ 并发 + 算法 + 框架
前言
在过 2 个月即将进入 3 月了,然而面对今年的大环境而言,跳槽成功的难度比往年高了很多,很明显的感受就是:对于今年的 java 开发朋友跳槽面试,无论一面还是二面,都开始考验一个 Java 程序员的技术功底和基础。对源码解读和核心原理理解也是成了加分项,特别是对 Java 的一些核心基础知识点掌握的不够或者没有体系方向的朋友面试也成了一个苦恼的事情。
今天在这分享目前国内公司 Java 面试常问的问题包括 JVM、常用的算法和数据结构,redis 缓存,分布式,Spring,微服务等。正所谓知己知彼,只有体系知识巩固,面对不断更新的技术才能快速掌握,同时在面试、工作中也更能脱颖而出!
300 道高频常问 Java 体系面试问题
Java 集合 22 题
-
ArrayList 和 Vector 的区别。
-
说说 ArrayList,Vector, LinkedList 的存储性能和特性。
-
快速失败 (fail-fast) 和安全失败 (fail-safe) 的区别是什么?
-
hashmap 的数据结构。
-
HashMap 的工作原理是什么?
-
Hashmap 什么时候进行扩容呢?
-
List、Map、Set 三个接口,存取元素时,各有什么特点?
-
Set 里的元素是不能重复的,那么用什么方法来区分重复与否呢? 是用 == 还是 equals()? 它们有何区别?
-
两个对象值相同 (x.equals(y) == true),但却可有不同的 hash code,这句话对不对?
-
heap 和 stack 有什么区别。
-
Java 集合类框架的基本接口有哪些?
-
HashSet 和 TreeSet 有什么区别?
-
HashSet 的底层实现是什么?
-
LinkedHashMap 的实现原理?
-
为什么集合类没有实现 Cloneable 和 Serializable 接口?
-
什么是迭代器 (Iterator)?
-
Iterator 和 ListIterator 的区别是什么?
-
数组 (Array) 和列表 (ArrayList) 有什么区别?什么时候应该使用 Array 而不是 ArrayList?
-
Java 集合类框架的最佳实践有哪些?
-
Set 里的元素是不能重复的,那么用什么方法来区分重复与否呢?是用 == 还是 equals()?它们有何区别?
-
Comparable 和 Comparator 接口是干什么的?列出它们的区别
-
Collection 和 Collections 的区别。
JVM 与调优 21 题
-
Java 类加载过程?
-
描述一下 JVM 加载 Class 文件的原理机制?
-
Java 内存分配。
-
GC 是什么? 为什么要有 GC?
-
简述 Java 垃圾回收机制
-
如何判断一个对象是否存活?(或者 GC 对象的判定方法)
-
垃圾回收的优点和原理。并考虑 2 种回收机制
-
垃圾回收器的基本原理是什么?垃圾回收器可以马上回收内存吗?有什么办法主动通知虚拟机进行垃圾回收?
-
Java 中会存在内存泄漏吗,请简单描述
-
深拷贝和浅拷贝。
-
System.gc() 和 Runtime.gc() 会做什么事情?
-
finalize() 方法什么时候被调用?析构函数 (finalization) 的目的是什么?
-
如果对象的引用被置为 null,垃圾收集器是否会立即释放对象占用的内存?
-
什么是分布式垃圾回收(DGC)?它是如何工作的?
-
串行(serial)收集器和吞吐量(throughput)收集器的区别是什么?
-
在 Java 中,对象什么时候可以被垃圾回收?
-
简述 Java 内存分配与回收策率以及 Minor GC 和 Major GC。
-
JVM 的永久代中会发生垃圾回收么?
-
Java 中垃圾收集的方法有哪些?
-
什么是类加载器,类加载器有哪些?
-
类加载器双亲委派模型机制?
并发编程 28 题
-
Synchronized 用过吗,其原理是什么?
-
你刚才提到获取对象的锁,这个“锁”到底是什么?如何确定对象的锁?
-
什么是可重入性,为什么说 Synchronized 是可重入锁?
-
JVM 对 Java 的原生锁做了哪些优化?48
-
为什么说 Synchronized 是非公平锁?49
-
什么是锁消除和锁粗化?49
-
为什么说 Synchronized 是一个悲观锁?乐观锁的实现原理又是什么?什么是 CAS,它有什么特性?
-
乐观锁一定就是好的吗?
-
跟 Synchronized 相比,可重入锁 ReentrantLock 其实现原理有什么不同?
-
那么请谈谈 AQS 框架是怎么回事儿?
-
请尽可能详尽地对比下 Synchronized 和 ReentrantLock 的异同。
-
ReentrantLock 是如何实现可重入性的?
-
除了 ReetrantLock,你还接触过 JUC 中的哪些并发工具?
-
请谈谈 ReadWriteLock 和 StampedLock。
-
如何让 Java 的线程彼此同步?你了解过哪些同步器?请分别介绍下。
-
CyclicBarrier 和 CountDownLatch 看起来很相似,请对比下呢?
-
Java 线程池相关问题
-
Java 中的线程池是如何实现的?
-
创建线程池的几个核心构造参数?
-
线程池中的线程是怎么创建的?是一开始就随着线程池的启动创建好的吗?
-
既然提到可以通过配置不同参数创建出不同的线程池,那么 Java 中默认实现好的线程池又有哪些呢?请比较它们的异同
-
如何在 Java 线程池中提交线程?
-
什么是 Java 的内存模型,Java 中各个线程是怎么彼此看到对方的变量的?
-
请谈谈 volatile 有什么特点,为什么它能保证变量对所有线程的可见性?
-
既然 volatile 能够保证线程间的变量可见性,是不是就意味着基于 volatile 变量的运算就是并发安全的?
-
请对比下 volatile 对比 Synchronized 的异同。
-
请谈谈 ThreadLocal 是怎么解决并发安全的?
-
很多人都说要慎用 ThreadLocal,谈谈你的理解,使用 ThreadLocal 需要注意些什么?
Spring25 题
微服务 58 题(SpringBoot,SpringCloud,Dubbo)
Netty10 题
-
BIO、NIO 和 AIO 的区别?
-
NIO 的组成?
-
Netty 的特点?
-
Netty 的线程模型?
-
TCP 粘包/拆包的原因及解决方法?
-
了解哪几种序列化协议?
-
如何选择序列化协议?
-
Netty 的零拷贝实现?
-
Netty 的高性能表现在哪些方面?
-
NIOEventLoopGroup 源码?
网络
-
网络 7 层架构
-
TCP/IP 原理
-
TCP 三次握手/四次挥手
-
HTTP 原理
-
传输流程
-
HTTP 状态
-
CDN 原理
Redis
-
什么是 redis?
-
Reids 的特点
-
Redis 支持的数据类型
-
Redis 是单进程单线程的
-
虚拟内存
-
Redis 锁
-
读写分离模型
-
数据分片模型
-
Redis 的回收策略
-
使用 Redis 有哪些好处?
-
redis 相比 memcached 有哪些优势?4
-
redis 常见性能问题和解决方案
-
MySQL 里有 2000w 数据,redis 中只存 20w 的数据,如何保证 redis 中的数据都是热点数据 245
-
Memcache 与 Redis 的区别都有哪些?
-
Redis 常见的性能问题都有哪些?如何解决?
-
Redis 最适合的场景
Zookeeper,Kafka
全部目录及答案展示,其中数据结构我分开整理了
读者福利
更多笔记分享