关于java:Java面试题总结附答案

41次阅读

共计 8701 个字符,预计需要花费 22 分钟才能阅读完成。

题目篇

一、Java 根底

1、JDK 和 JRE 有什么区别?

2、== 和 equals 的区别是什么?

3、两个对象的 hashCode()雷同,则 equals()也肯定为 true,对吗?

4、final 在 java 中有什么作用?

5、java 中的 Math.round(-1.5) 等于多少?

6、String 属于根底的数据类型吗?

7、java 中操作字符串都有哪些类?它们之间有什么区别?

8、String str=”i” 与 String str=new String(“i”)一样吗?

9、如何将字符串反转?

10、String 类的罕用办法都有那些?

11、抽象类必须要有形象办法吗?

12、一般类和抽象类有哪些区别?

13、抽象类能应用 final 润饰吗?

14、接口和抽象类有什么区别?

15、java 中 IO 流分为几种?

16、BIO、NIO、AIO 有什么区别?

17、Files 的罕用办法都有哪些?

18、什么是反射?

19、什么是 java 序列化?什么状况下须要序列化?

20、动静代理是什么?有哪些利用?

21、怎么实现动静代理?

22、为什么要应用克隆?

23、如何实现对象克隆?

24、深拷贝和浅拷贝区别是什么?

25、throw 和 throws 的区别?

26、final、finally、finalize 有什么区别?

27、try-catch-finally 中哪个局部能够省略?

28、try-catch-finally 中,如果 catch 中 return 了,finally 还会执行吗?

29、常见的异样类有哪些?

30、new String(“a”) + new String(“b”) 会创立几个对象?

二、Java 汇合

1、java 容器都有哪些?

2、Collection 和 Collections 有什么区别?

3、List、Set、Map 之间的区别是什么?

4、HashMap 和 Hashtable 有什么区别?

5、说一下 HashMap 的实现原理?

6、set 有哪些实现类?

7、说一下 HashSet 的实现原理?

8、ArrayList 和 LinkedList 的区别是什么?

9、如何实现数组和 List 之间的转换?

10、ArrayList 和 Vector 的区别是什么?

11、Array 和 ArrayList 有何区别?

12、在 Queue 中 poll()和 remove()有什么区别?

13、哪些汇合类是线程平安的?

14、迭代器 Iterator 是什么?

15、Iterator 怎么应用?有什么特点?

16、Iterator 和 ListIterator 有什么区别?

17、怎么确保一个汇合不能被批改?

18、队列和栈是什么?有什么区别?

三、多线程

1、Synchronized 用过吗,其原理是什么?

2、请比照下 volatile 比照 Synchronized 的异同。

3、请谈谈 volatile 有什么特点,为什么它能保障变量对所有线程的可见性?

4、JVM 对 Java 的原生锁做了哪些优化?

5、为什么说 Synchronized 是非偏心锁?

6、什么是锁打消和锁粗化?

7、为什么说 Synchronized 是一个乐观锁?乐观锁的实现原理又是什么?什么是 CAS,它有什么个性?

8、乐观锁肯定就是好的吗?

9、跟 Synchronized 相比,可重入锁 ReentrantLock 其实现原理有什么不同?

10、那么请谈谈 AQS 框架是怎么回事儿?

11、请尽可能详尽地比照下 Synchronized 和 ReentrantLock 的异同。

12、ReentrantLock 是如何实现可重入性的?

13、除了 ReetrantLock,你还接触过 JUC 中的哪些并发工具?

14、请谈谈 ReadWriteLock 和 StampedLock。

15、如何让 Java 的线程彼此同步?你理解过哪些同步器?请别离介绍下。

16、CyclicBarrier 和 CountDownLatch 看起来很类似,请比照下呢?

17、Java 线程池相干问题

18、Java 中的线程池是如何实现的?

19、创立线程池的几个外围结构参数?

20、线程池中的线程是怎么创立的?是一开始就随着线程池的启动创立好的吗?

21、既然提到能够通过配置不同参数创立出不同的线程池,那么 Java 中默认实现好的线程池又有哪些呢?请比拟它们的异同

22、如何在 Java 线程池中提交线程?

23、什么是 Java 的内存模型,Java 中各个线程是怎么彼此看到对方的变量的?

24、ThreadLocal 是什么?有哪些应用场景?

25、既然 volatile 可能保障线程间的变量可见性,是不是就意味着基于 volatile 变量的运算就是并发平安的?

26、Java8 开始 ConcurrentHashMap, 为什么舍弃分段锁?

27、请谈谈 ThreadLocal 是怎么解决并发平安的?

28、很多人都说要慎用 ThreadLocal,谈谈你的了解,应用 ThreadLocal 须要留神些什么?

29、什么是上下文切换?

30、线程的 run()和 start()有什么区别?

31、为什么咱们调用 start() 办法时会执行 run() 办法,为什么咱们不能间接调用 run() 办法?

32、什么是线程调度器 (Thread Scheduler) 和工夫分片(Time Slicing)?

33、为什么 wait(), notify()和 notifyAll()必须在同步办法或者同步块中被调用?

34、Thread 类中的 yield 办法有什么作用?

35、Java 如何实现多线程之间的通信和合作?

36、为什么代码会重排序?

37、什么是自旋

38、多线程中 synchronized 锁降级的原理是什么?

39、synchronized 和 ReentrantLock 区别是什么?

40、volatile 关键字的作用

41、Java Concurrency API 中的 Lock 接口 (Lock interface) 是什么?比照同步它有什么劣势?

42、AQS 是什么?

43、AQS 对资源的共享形式?

四、Java Web

1、jsp 和 servlet 有什么区别?

2、jsp 有哪些内置对象?作用别离是什么?

3、说一下 jsp 的 4 种作用域?

4、session 和 cookie 有什么区别?

5、说一下 session 的工作原理?

6、如果客户端禁止 cookie 能实现 session 还能用吗?

7、spring mvc 和 struts 的区别是什么?

8、如何防止 sql 注入?

9、什么是 XSS 攻打,如何防止?

10、什么是 CSRF 攻打,如何防止?

五、网络

1、http 响应码 301 和 302 代表的是什么?有什么区别?

2、forward 和 redirect 的区别?

3、简述 tcp 和 udp 的区别?

4、tcp 为什么要三次握手,两次不行吗?为什么?

5、说一下 tcp 粘包是怎么产生的?

6、OSI 的七层模型都有哪些?

7、get 和 post 申请有哪些区别?

8、如何实现跨域?

9、说一下 JSONP 实现原理?

六、设计模式

1、请列举出在 JDK 中几个罕用的设计模式?

2、什么是设计模式?你是否在你的代码外面应用过任何设计模式?

3、Java 中什么叫单例设计模式?请用 Java 写出线程平安的单例模式

4、在 Java 中,什么叫观察者设计模式(observer design pattern)?

5、应用工厂模式最次要的益处是什么?在哪里应用?

6、举一个用 Java 实现的装璜模式(decorator design pattern)?它是作用于对象档次还是类档次?

7、在 Java 中,为什么不容许从静态方法中拜访非动态变量?

8、设计一个 ATM 机,请说出你的设计思路?

9、在 Java 中,什么时候用重载,什么时候用重写?

10、举例说明什么状况下会更偏向于应用抽象类而不是接口

七、Spring/SpringMVC

1、什么是 Spring 框架?Spring 框架有哪些次要模块?

2、应用 Spring 框架能带来哪些益处?

3、什么是管制反转(IOC)?什么是依赖注入?

4、请解释下 Spring 框架中的 IoC?

5、BeanFactory 和 ApplicationContext 有什么区别?

6、Spring 有几种配置形式?

7、请解释 Spring Bean 的生命周期?

8、Spring Bean 的作用域之间有什么区别?

9、什么是 Spring inner beans?

10、Spring 框架中的单例 Beans 是线程平安的么?

11、请举例说明如何在 Spring 中注入一个 Java Collection?

12、如何向 Spring Bean 中注入一个 Java.util.Properties?

13、请解释 Spring Bean 的主动拆卸?

14、请解释主动拆卸模式的区别?

15、如何开启基于注解的主动拆卸?

16、请举例解释 @Required 注解?

17、请举例解释 @Autowired 注解?

18、请举例说明 @Qualifier 注解?

19、构造方法注入和设值注入有什么区别?

20、Spring 框架中有哪些不同类型的事件?

21、FileSystemResource 和 ClassPathResource 有何区别?

22、Spring 框架中都用到了哪些设计模式?

八、Spring Boot/Spring Cloud

1、什么是 Spring Boot?

2、Spring Boot 有哪些长处?

3、什么是 JavaConfig?

5、Spring Boot 中的监视器是什么?

6、如何在 Spring Boot 中禁用 Actuator 端点安全性?

7、如何在自定义端口上运行 Spring Boot 应用程序?

8、什么是 YAML?

9、如何实现 Spring Boot 应用程序的安全性?

10、如何集成 Spring Boot 和 ActiveMQ?

11、如何应用 Spring Boot 实现分页和排序?

12、什么是 Swagger?你用 Spring Boot 实现了它吗?

13、什么是 Spring Profiles?

14、什么是 Spring Batch?

15、什么是 FreeMarker 模板?

16、如何应用 Spring Boot 实现异样解决?

17、您应用了哪些 starter maven 依赖项?

18、什么是 CSRF 攻打?

19、什么是 WebSockets?

20、什么是 AOP?

21、什么是 Apache Kafka?

22、咱们如何监督所有 Spring Boot 微服务?

23、什么是 spring cloud?

24、spring cloud 断路器的作用是什么?

26、spring cloud 的外围组件有哪些?

九、Hibernate

1、为什么要应用 hibernate?

2、什么是 ORM 框架?

3、hibernate 中如何在控制台查看打印的 sql 语句?

4、hibernate 有几种查问形式?

5、hibernate 实体类能够被定义为 final 吗?

6、在 hibernate 中应用 Integer 和 int 做映射有什么区别?

7、hibernate 是如何工作的?

8、get()和 load()的区别?

9、说一下 hibernate 的缓存机制?

10、hibernate 对象有哪些状态?

11、在 hibernate 中 getCurrentSession 和 openSession 的区别是什么?

12、hibernate 实体类必须要有无参构造函数吗?为什么?

十、MyBatis

1、mybatis 中 #{}和 ${}的区别是什么?

2、mybatis 有几种分页形式?

3、RowBounds 是一次性查问全副后果吗?为什么?

4、mybatis 逻辑分页和物理分页的区别是什么?

5、mybatis 是否反对提早加载?提早加载的原理是什么?

6、说一下 mybatis 的一级缓存和二级缓存?

7、mybatis 和 hibernate 的区别有哪些?

8、mybatis 有哪些执行器(Executor)?

9、mybatis 分页插件的实现原理是什么?

10、mybatis 如何编写一个自定义插件?

十一、RabbitMQ

1、RabbitMQ 的应用场景有哪些?

2、RabbitMQ 有哪些重要的角*r /> 3、RabbitMQ 有哪些重要的组件?

4、RabbitMQ 中 vhost 的作用是什么?

5、RabbitMQ 的音讯是怎么发送的?

6、RabbitMQ 怎么保障音讯的稳定性?

7、RabbitMQ 怎么防止音讯失落?

8、要保障音讯长久化胜利的条件有哪些?

9、RabbitMQ 长久化有什么毛病?

10、RabbitMQ 有几种播送类型?

11、RabbitMQ 怎么实现提早音讯队列?

12、RabbitMQ 集群有什么用?

13、RabbitMQ 节点的类型有哪些?

14、RabbitMQ 集群搭建须要留神哪些问题?

15、RabbitMQ 每个节点是其余节点的残缺拷贝吗?为什么?

16、RabbitMQ 集群中惟一一个磁盘节点解体了会产生什么状况?

17、RabbitMQ 对集群节点进行程序有要求吗?

十二、Kafka(未把握,临时不做)

如何获取 topic 主题的列表

生产者和消费者的命令行是什么?

consumer 是推还是拉?

讲讲 kafka 保护生产状态跟踪的办法

讲一下主从同步

为什么须要音讯零碎,mysql 不能满足需要吗?

Zookeeper 对于 Kafka 的作用是什么?

数据传输的事务定义有哪三种?

Kafka 判断一个节点是否还活着有那两个条件?

Kafka 与传统 MQ 音讯零碎之间有三个要害区别

讲一讲 kafka 的 ack 的三种机制

消费者如何不主动提交偏移量,由利用提交?

消费者故障,呈现活锁问题如何解决?

如何管制生产的地位

kafka 分布式(不是单机)的状况下,如何保障音讯的程序生产?

kafka 的高可用机制是什么?

kafka 如何缩小数据失落

kafka 如何不生产反复数据?比方扣款,咱们不能反复的扣。

十三、Zookeeper(未把握,临时不做)

ZooKeeper 提供了什么?

Zookeeper 文件系统

ZAB 协定?

四种类型的数据节点 Znode

Zookeeper Watcher 机制 – 数据变更告诉

客户端注册 Watcher 实现

服务端解决 Watcher 实现

客户端回调 Watcher

ACL 权限管制机制

Chroot 个性

会话治理

服务器角*r /> Zookeeper 下 Server 工作状态

数据同步

zookeeper 是如何保障事务的程序一致性的?

分布式集群中为什么会有 Master?

zk 节点宕机如何解决?

zookeeper 负载平衡和 nginx 负载平衡区别

Zookeeper 有哪几种几种部署模式?

集群起码要几台机器,集群规定是怎么的?

集群反对动静增加机器吗?

Zookeeper 对节点的 watch 监听告诉是永恒的吗?为什么不是永恒的?

Zookeeper 的 java 客户端都有哪些?

chubby 是什么,和 zookeeper 比你怎么看?

说几个 zookeeper 罕用的命令。

ZAB 和 Paxos 算法的分割与区别?

Zookeeper 的典型利用场景

十四、MySql

1、数据库的三范式是什么?

2、一张自增表外面总共有 7 条数据,删除了最初 2 条数据,重启 mysql 数据库,又插入了一条数据,此时 id 是几?

3、如何获取以后数据库版本?

4、说一下 ACID 是什么?

5、char 和 varchar 的区别是什么?

6、float 和 double 的区别是什么?

7、mysql 的内连贯、左连贯、右连贯有什么区别?

8、mysql 索引是怎么实现的?

9、怎么验证 mysql 的索引是否满足需要?

10、说一下数据库的事务隔离?

11、说一下 mysql 罕用的引擎?

12、说一下 mysql 的行锁和表锁?

13、说一下乐观锁和乐观锁?

14、mysql 问题排查都有哪些伎俩?

15、如何做 mysql 的性能优化?

十五、Redis

1、Redis 是什么?都有哪些应用场景?

2、Redis 有哪些性能?

3、Redis 和 memecache 有什么区别?

4、Redis 为什么是单线程的?

5、什么是缓存穿透?怎么解决?

6、Redis 反对的数据类型有哪些?

7、Redis 反对的 java 客户端都有哪些?

8、jedis 和 redisson 有哪些区别?

9、怎么保障缓存和数据库数据的一致性?

10、Redis 长久化有几种形式?

11、Redis 怎么实现分布式锁?

12、Redis 分布式锁有什么缺点?

13、Redis 如何做内存优化?

14、Redis 淘汰策略有哪些?

15、Redis 常见的性能问题有哪些?该如何解决?

十六、JVM

1、说一下 jvm 的次要组成部分?及其作用?

2、说一下 jvm 运行时数据区?

3、说一下堆栈的区别?

4、什么是类加载器,类加载器有哪些?

5、什么是双亲委派模型?

6、说一下类加载的执行过程?

7、怎么判断对象是否能够被回收?

8、java 中都有哪些援用类型?

9、说一下 jvm 有哪些垃圾回收算法?

10、说一下 jvm 有哪些垃圾回收器?

11、具体介绍一下 CMS 垃圾回收器?

12、新生代垃圾回收器和老生代垃圾回收器都有哪些?有什么区别?

13、简述分代垃圾回收器是怎么工作的?

14、说一下 jvm 调优的工具?

15、罕用的 jvm 调优的参数都有哪些?

16、Java 类加载过程?

17、形容一下 JVM 加载 Class 文件的原理机制?

18、Java 内存调配。

19、GC 是什么? 为什么要有 GC?

20、简述 Java 垃圾回收机制

21、如何判断一个对象是否存活?(或者 GC 对象的断定办法)

22、垃圾回收的长处和原理。并思考 2 种回收机制

23、垃圾回收器的基本原理是什么?垃圾回收器能够马上回收内存吗?有什么方法被动告诉虚拟机进行垃圾回收?

24、Java 中会存在内存透露吗,请简略形容

25、深拷贝和浅拷贝。

26、System.GC() 和 Runtime.GC() 会做什么事件?

27、finalize() 办法什么时候被调用?析构函数 (finalization) 的目标是什么?

28、如果对象的援用被置为 null,垃圾收集器是否会立刻开释对象占用的内存?

29、串行(serial)收集器和吞吐量(throughput)收集器的区别是什么?

30、在 Java 中,对象什么时候能够被垃圾回收?

31、简述 Java 内存调配与回收策略以及 Minor GC 和 Major GC。

32、VM 的永恒代中会产生垃圾回收么?

33、Java 中垃圾收集的办法有哪些?

十七、Dubbo 面试题(未把握,临时不做)

为什么要用 Dubbo?

Dubbo 的整体架构设计有哪些分层?

默认应用的是什么通信框架,还有别的抉择吗?

服务调用是阻塞的吗?

个别应用什么注册核心?还有别的抉择吗?

默认应用什么序列化框架,你晓得的还有哪些?

服务提供者能实现生效踢出是什么原理?

服务上线怎么不影响旧版本?

如何解决服务调用链过长的问题?

说说外围的配置有哪些?

Dubbo 举荐用什么协定?

同一个服务多个注册的状况下能够直连某一个服务吗?

画一画服务注册与发现的流程图?

Dubbo 集群容错有几种计划?

Dubbo 服务降级,失败重试怎么做?

Dubbo 应用过程中都遇到了些什么问题?

Dubbo Monitor 实现原理?

Dubbo 用到哪些设计模式?

Dubbo 配置文件是如何加载到 Spring 中的?

Dubbo SPI 和 Java SPI 区别?

Dubbo 反对分布式事务吗?

Dubbo 能够对后果进行缓存吗?

服务上线怎么兼容旧版本?

Dubbo 必须依赖的包有哪些?

Dubbo telnet 命令能做什么?

Dubbo 反对服务降级吗?

Dubbo 如何优雅停机?

Dubbo 和 Dubbox 之间的区别?

Dubbo 和 Spring Cloud 的区别?

你还理解别的分布式框架吗?

十八、Elasticsearch 面试题(未把握,临时不做)

elasticsearch 理解多少,说说你们公司 es 的集群架构,索引数据大小,分片有多少,以及一些调优伎俩。

elasticsearch 的倒排索引是什么

elasticsearch 索引数据多了怎么办,如何调优,部署

elasticsearch 是如何实现 master 选举的

详细描述一下 Elasticsearch 索引文档的过程

详细描述一下 Elasticsearch 搜寻的过程?

Elasticsearch 在部署时,对 Linux 的设置有哪些优化办法

lucence 内部结构是什么?

Elasticsearch 是如何实现 Master 选举的?

Elasticsearch 中的节点(比方共 20 个),其中的 10 个选了一个 master,另外 10 个选了另一个 master,怎么办?

客户端在和集群连贯时,如何抉择特定的节点执行申请的?

详细描述一下 Elasticsearch 索引文档的过程。

详细描述一下 Elasticsearch 更新和删除文档的过程。

详细描述一下 Elasticsearch 搜寻的过程

在 Elasticsearch 中,是怎么依据一个词找到对应的倒排索引的?

Elasticsearch 在部署时,对 Linux 的设置有哪些优化办法?

对于 GC 方面,在应用 Elasticsearch 时要留神什么?

Elasticsearch 对于大数据量(上亿量级)的聚合如何实现?

在并发状况下,Elasticsearch 如果保障读写统一?

如何监控 Elasticsearch 集群状态?

介绍下你们电商搜寻的整体技术架构

介绍一下你们的个性化搜寻计划?

是否理解字典树?

拼写纠错是如何实现的?

能够说这一篇(宝典)说实话,熟知本文 80% 以上内容,找个开发工作问题不大。对 3 - 5 年教训的敌人,也是疾速复习的利器。

私信我评论(学习)收费获取答案

 最次要的是给本人减少常识的储备,有恃无恐。最初给大家分享 Spring 系列的学习笔记和面试题,蕴含 spring 面试题、spring cloud 面试题、spring boot 面试题、spring 教程笔记、spring boot 教程笔记、最新阿里巴巴开发手册(63 页 PDF 总结)、2022 年 Java 面试手册。一共整顿了 1184 页 PDF 文档。私信博主(666)支付,祝大家更上一层楼!!!

正文完
 0