前言
现如今,Java 面试的本质就是八股文,把八股文面试题背好,面试才有可能表现好。金九银十招聘黄金季已经来临!大家在考研和找工作中纠结的时候,不妨先看一下面试题,毕竟我们的最终目标就是为了找一份心仪的工作!好工作都是早下手为强的,所以同学们要早做准备!
1、JDK、JRE. JVM 之间的区别
- JDK:Java 标准开发包,它提供了编译、运⾏Java 程序所需的各种⼯具和资源,包括 Java 编译器、Java 运⾏时环境,以及常⽤的 Java 类库等
- JRE:Java 运⾏环境,⽤于运⾏Java 的字节码⽂件。JRE 中包括了 JVM 以及 JVM⼯作所需要的类库,普通⽤户⽽只需要安装 JRE 来运⾏Java 程序,⽽程序开发者必须安装 JDK 来编译、调试程序。
- JVM:Java 虚拟机,是 JRE 的⼀部分,它是整个 java 实现跨平台的最核⼼的部分,负责运⾏字节码⽂件。
2、hashCode()与 equals()之间的关系
在 Java 中,每个对象都可以调⽤⾃⼰的 hashCode()⽅法得到⾃⼰的哈希值(hashCode),相当于对象的指纹信息,通常来说世界上没有完全相同的两个指纹,但是在 Java 中做不到这么绝对,但是我们仍然可以利⽤hashCode 来做⼀些提前的判断,⽐如:
- 如果两个对象的 hashCode 不相同,那么这两个对象肯定不同的两个对象
- 如果两个对象的 hashCode 相同,不代表这两个对象⼀定是同⼀个对象,也可能是两个对象
- 如果两个对象相等,那么他们的 hashCode 就⼀定相同
3、String. StringBuffer. StringBuilder 的区别
- String 是不可变的,如果尝试去修改,会新⽣成⼀个字符串对象,StringBuffer 和 StringBuilder 是可变的
- StringBuffer 是线程安全的,StringBuilder 是线程不安全的,所以在单线程环境下 StringBuilder 效率会更⾼
4、泛型中 extends 和 super 的区别
- <? extends T>表示包括 T 在内的任何 T 的⼦类
- <? super T>表示包括 T 在内的任何 T 的⽗类
5、==和 equals 方法的区别
- ==:如果是基本数据类型,⽐较是值,如果是引⽤类型,⽐较的是引⽤地址
- equals:具体看各个类重写 equals⽅法之后的⽐较逻辑,⽐如 String 类,虽然是引⽤类型,但是 String 类中重写了 equals⽅法,⽅法内部⽐较的是字符串中的各个字符是否全部相等。
6、重载和重写的区别
7、List 和 Set 的区别
8、ArrayList 和 LinkedList 区别
9、谈谈 ConcurrentHashMap 的扩容机制
10、Jdk1.7 到 Jdk1.8 HashMap 发生了什么变化(底层)?
11、说一下 HashMap 的 Put 方法
12、深拷贝和浅拷贝
13、HashMap 的扩容机制原理
14、CopyOnWriteArrayList 的底层原理是怎样的
15、什么是字节码?采用字节码的好处是什么?
16、Java 中的异常体系是怎样的
17、在 Java 的异常处理机制中,什么时候应该抛出异常,什么时候捕获异常?
18、Java 中有哪些类加载器
19、说说类加载器双亲委派模型
20、JVM 中哪些是线程共享区
21、你们项目如何排查 JVM 问题
22、一个对象从加载到 JVM,再到被 GC 清除, 都经历了什么过程?
23、怎么确定-一个对象到底是不是垃圾?
24、JVM 有哪些垃圾回收算法?
25、什么是 STW?
26、JVM 参数有哪些? .
27、说说对线程安全的理解
28、对守护线程的理解
29、ThreadLocal 的底层原理
30、并发、并行。串行之间的区别
31、Java 死锁如何避免?
32、线程池的底层工作原理
33、线程池为什么是先添加列队而不是先创建最大线程?
34、ReentrantL 0ock 中的公平锁和非公平锁的底层实现
35、ReentrantL .ock 中 tryL ock)和 lock)方法的区别
36、CountDownLatch 和 Semaphore 的区别和底层原理
37、Sychronized 的偏向锁、轻量级锁、重量级锁
38、Sychronized 和 ReentrantLock 的区别
39、谈谈你对 AQS 的理解,AQS 如何实现可重入锁?
40、谈谈你对 I0C 的理解
41、单例 Bean 和单例模式
42、Spring 事务传播机制
43、Spring 事务什么时候会失效?
44、Spring 中的 Bean 创建的生命周期有哪些步骤
45、Spring 中 Bean 是线程安全的吗
46、ApplicationContext 和 BeanFactory 有什么区别
47、Spring 中的事务是如何实现的
48、Spring 中什么时候 @Transactional 会失效
49、Spring 容器启动流程是怎样的
50、Spring 用到了哪些设计模式
51、Spring Boot 中常用注解及其底层实现
52、Spring Boot 是如何启动 Tomcat 的
53、Mybatis 的优缺点
54、#0 和 $0 的区别是什么?
55、索引的基本原理
56、索引设计的原则?
57、事务的基本特性和隔离级别
58、什么是 MVCC
59、简述 MyISAM 和 InnoDB 的区别
60、Explain 语句结果中各个字段分表表示什么
61、索引覆盖是什么
62、最左前提原则是什么
63、Innodb 是如何实现事务的
64、B 树和 B+树的区别,为什么 Mysq|使用 B+树
65、Mysql 锁有哪些,如何理解
66、Mysq|懂查询该如何优化?
67、什么是 RDB 和 AOF
68、Redis 的过期键的删除策略
69、简述 Redis 事务实现
70、Redis 主从复制的核心原理
71、Redis 有哪些数据结构?分别有哪些典型的应用场景?
72、Redis 分布式锁底层是如何实现的?
73、Redis 主.从复制的核心原理
74、Redis 集群策略
75、缓存穿透。缓存击穿,缓存雪崩分别是什么
76、Redis 和 Mysql 如何保证数据- -致
77、Redis 的持文化机制
78、Redis 单线程为什么这么快
80、什么是 CAP 理论
81、什么是 BASE 理论
82、什么是 RPC
83、数据一-致性模型有哪些
84、分布式 D 是什么?有哪些解决方案?
85、分布式锁的使用场最是什么?有哪些实现方案?
86、什么是分布式事务?有哪些实现方案?
87、什么是 ZAB 协议
88、为什么 Zookeeper 可以用来作为注册中心
89、Zookeeper 中的领导者选举的流程是怎样的?
90、Zookeeper 集群中节点之间数据是如何同步的
91、Dubbo 支持哪些负载均勸策略
92、Dubbo 是如何完成服务导出的?
93、Dubbo 是如何完成服务引入的?
94、Dubo 的架构设计是怎样的?
95、负载均衢算法有哪些
96、分布式架构下,Session 共享有什么方案
97、如何实现接口的冪等性
98、简述 zk 的命名服务。配置管理、集群管理
99、讲下 Zookeeper 中的 watch 机制
100、Zookeeper 和 Eureka 的区别
101、存储拆分后如何解决唯-主键问题
102、雪花算法原理
103、如何解决不使用分区键的查询问题
104、Spring Cloud 有哪些常用组件,作用是什么?
105、如何避免缓存穿透、缓存击穿。缓存雪崩?
106、分布式系统中常用的缓存方案有哪些
107、缓存过期都有哪些策略?
108、常见的缓存淘汰算法
109、布隆过滤器原理,优缺点
110、分布式缓存寻址算法
111、Spring Cloud 和 Dubbo 有哪些区别?
112、什么是服务雪崗?什么是服务限流?
113、什么是服务熔断?什么是服务降级?区别是什么?
114、SOA、分布式,微服务之间有什么关系和区别?
115、怎么拆分微服务?
116、怎样设计出高内聚,低耦合的微服务?
117、有没有了解过 DDD 领域驱动设计?
118、什么是中台?
119、你的项目中是怎么保证微服务敏捷开发的?
120、如何进行消息队列选型?
121、RocketMQ 的事务消息是如何实现的
122、为什么 RocketMO 不使用 ookeeper 作为注册中心呢?
123、RocketMQ 的实现原理
124、RocketMQ 为什么速度快
125、消息队列如何保证消息可靠传输
126、消息队列有哪些作用
127、死信队列是什么?延时队列是什么?
128、如何保证消息的高效读写?
129、epoll 和 poll 的区别
130、TCP 的三次握手和四次挥手
131、浏览器发出一个请求到收到响应经历了哪些步骤?
132、跨域请求是什么?有什么问题?怎么解决?
133、零拷贝是什么