对今年的大环境而言,跳槽成功的难度比往年高了很多,很明显的感受就是:对于今年的java开发朋友跳槽面试,无论一面还是二面,都开始考验一个Java程序员的技术功底和基础。对源码解读和核心原理理解也是成了加分项,特别是对 Java 的一些核心基础知识点掌握的不够或者没有体系方向的朋友面试也成了一个苦恼的事情。
今天在这分享大厂Java面试常问的问题包括JVM、常用的算法和数据结构,redis缓存,分布式,Spring,微服务等。正所谓知己知彼,只有体系知识巩固,面对不断更新的技术才能快速掌握,同时在面试、工作中也更能脱颖而出!
Java集合
- 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与调优
- 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 中垃圾收集的方法有哪些?
- 什么是类加载器,类加载器有哪些?
- 类加载器双亲委派模型机制?
并发编程
- 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 需要注意些什么?
Spring
1、什么是Spring框架? Spring框架有哪些主要模块?
2、使用Spring框架能带来哪些好处?
3、什么是控制反转(IOC)?什么是依赖注入?
4、请解释下Spring 框架中的IoC?
5、BeanFactory 和ApplicationContext有什么区别?
6.Spring有几种配置方式?
7、如何用基于XML配置的方式配置Spring ?
8、如何用基于Java配置的方式配置Spring ?
9、怎样用注解的方式配置Spring ?
10、请解释SpringBean的生命周期?
11、Spring Bean的作用域之间有什么区别?
12、什么是Spring inner beans ?
13、Spring框架中的单例Beans是线程安全的么?
14、请举例说明如何在Spring中注入一个Java Collection ?
15、如何向Spring Bean中注入一个Java.util.Properties ?
16、请解释Spring Bean的自动装配?
17、请解释自动装配模式的区别?
18、如何开启基于注解的自动装配?
19请举例解释@Required注解?
20、请举例解释@Autowired注解?
22、构造方法注入和设值注入有什么区别?
23、Spring框架中有哪些不同美型的事件?
24、FileSystemResource和ClassPathResource有何区别?
25、Spring框架中都用到了哪些设计模式?
Redis
- 什么是redis?
- Reids的特点
- Redis支持的数据类型
- Redis是单进程单线程的
- 虚拟内存
- Redis锁
- 读写分离模型
- 数据分片模型
- Redis的回收策略
- 使用Redis有哪些好处?
- redis相比memcached有哪些优势?4
- redis常见性能问题和解决方案
- MySQL里有2000w数据,redis中只存20w的数据,如何保证redis中的数据都是热点数据245
- Memcache与Redis的区别都有哪些?
- Redis 常见的性能问题都有哪些?如何解决?
- Redis 最适合的场景
微服务58题(SpringBoot、SpringCloud、Dubbo)
SpringBoot面试题
- 什么是 Spring Boot?以及Spring Boot的优劣势?
- 为什么要用 Spring Boot?
- Spring Boot 的核心配置文件有哪几个?它们的区别是什么?
- Spring Boot 的配置文件有哪几种格式?它们有什么区别?
- Spring Boot 的核心注解是哪个?它主要由哪几个注解组成的?
- 开启 Spring Boot 特性有哪几种方式?
- Spring Boot 需要独立的容器运行吗?
- 运行 Spring Boot 有哪几种方式?
- Spring Boot 自动配置原理是什么?
- Spring Boot 的目录结构是怎样的?
- 你如何理解 Spring Boot 中的 Starters?
- 如何在 Spring Boot 启动的时候运行一些特定的代码?
- Spring Boot 有哪几种读取配置的方式?
- Spring Boot 支持哪些日志框架?推荐和默认的日志框架是哪个?
- SpringBoot 实现热部署有哪几种方式?
- 你如何理解 Spring Boot 配置加载顺序?
- Spring Boot 如何定义多套不同环境配置?
- Spring Boot 可以兼容老 Spring 项目吗,如何做?
- 保护 Spring Boot 应用有哪些方法?
- Spring Boot 2.X 有什么新特性?与 1.X 有什么区别?
Dubbo面试题
- Dubbo与DubboX区别
- Dubbo中zookeeper做注册中心,如果注册中心集群都挂掉,发布者和订阅者之间还能通信么?
- Dubbo中有哪些角色?
- Dubbo在安全机制方面是如何解决的
- Dubbo执行流程?
- Dubbo支持的协议有哪些?
- Dubbo支持的注册中心有哪些?
- dubbo服务负载均衡策略?
- dubbo核心的配置有哪些?dubbo推荐用什么协议?
- dubbo连接注册中心和直连的区别
- dubbo通信协议dubbo协议为什么不能传大包
- dubbo通信协议dubbo协议为什么要消费者比提供者个数多
- dubbo通信协议dubbo协议为什么采用异步单一长连接
- dubbo通信协议dubbo协议适用范围和适用场景
- Spring Cloud与Dubbo的区别是什么?
- 什么是Dubbo?
- 简述Dubbo的均衡策略和集群容错模式
- 为什么要用 Dubbo?
- Dubbo 的整体架构设计有哪些分层?
- 默认使用的是什么通信框架,还有别的选择吗?
- 服务调用是阻塞的吗?
- 一般使用什么注册中心?还有别的选择吗?
- 默认使用什么序列化框架,你知道的还有哪些?
- 服务提供者能实现失效踢出是什么原理?
- 服务上线怎么不影响旧版本?
- 如何解决服务调用链过长的问题?
- 说说核心的配置有哪些?
- Dubbo 推荐用什么协议?
- 同一个服务多个注册的情况下可以直连某一个服务吗?
- 画一画服务注册与发现的流程图?
- Dubbo 集群容错有几种方案?
- Dubbo 服务降级,失败重试怎么做?
- Dubbo 使用过程中都遇到了些什么问题?
- Dubbo Monitor 实现原理?
- Dubbo 用到哪些设计模式?
- Dubbo 配置文件是如何加载到 Spring 中的?
- Dubbo SPI 和 Java SPI 区别?
- Dubbo 支持分布式事务吗?
- Dubbo 可以对结果进行缓存吗?
- 服务上线怎么兼容旧版本?
- Dubbo 必须依赖的包有哪些?
- Dubbo telnet 命令能做什么?
- Dubbo 如何优雅停机?
- Dubbo 和 Spring Cloud 的区别?
- 你还了解别的分布式框架吗?
SpringCloud面试题
- 什么是 Spring Cloud?
- 使用 Spring Cloud 有什么优势?
- 服务注册和发现是什么意思?Spring Cloud 如何实现?
- Spring Cloud 和dubbo区别?
- SpringBoot和SpringCloud的区别?
- 负载平衡的意义什么?
- 什么是 Hystrix?它如何实现容错?
- 什么是 Hystrix 断路器?我们需要它吗?
- 什么是 Netflix Feign?它的优点是什么?
- 什么是 Spring Cloud Bus?我们需要它吗?
- Spring Cloud断路器的作用
- 什么是SpringCloudConfig?
- Spring Cloud Gateway?
后面还有关于 springMVC,netty,网络,zookeeper,kafka,rabbitMQ,数据库,设计模式等,就不在这里一一给大家展示了,
需要这些面试资料的读者朋友可以加微信:mxm1073 或 扫描文末二维码获取
最后,希望大家都能够拿到一个心怡的offer。