前言

致即将过去的2020年!

对于生命垂危的病人来说,时刻就是宝贵的生命;对于做生意的人来说,时刻就是财富,有的人说时刻就像是从山坡上流下来的水,从何处吹来的风,走了就不再回来了;而对于正在工作的我们来说,时刻就是力量,时刻就是财产。珍惜时刻就是掌握好生命的一半。

鲁迅说过:“时间,每天得到的都是二十四小时,可是一天的时间给勤勉的人带来智慧和力量,给懒散的人只留下一片悔恨。”

今天带给大家的是本人总结的2020年年度Java面试题。希望能对大家有帮助。

一、Java基础专题

1.面向对象和面向过程的区别(优点和缺点分别是什么?)

2.Java 语言有哪些特点?(8个点)

3.关于JVM JDK和JRE最详细通俗的解答。

4.Oracle JDK和OpenJDK的对比

5.Java和C++的区别。

6.什么是Java程序的主类应用程序和小程序的主类有何不同?

7.Java应用程序与小程序之间有哪些差别?

8.字符型常量和字符串常量的区别。

9.构造器Constructor是否可被override?

10.重载和重写的区别。

11.Java面向对象编程三大特性: 封装 继承 多态。

12.String StringBuffer和StringBuilder的区别是什么String为什么是不可变的?

13.自动装箱与拆箱

 

二、性能调优专题

JVM

1.内存模型以及分区,需要详细到每个区放什么?

2.堆里面的分区:Eden,survival(from+ to)老年代,各自的特点。

3.对象创建方法,对象的内存分配,对象的访问定位。

4.GC的两种判定方法,SafePoint是什么?

5.GC的三种收集方法:标记清除、标记整理、复制算法的原理与特点,分别用在什么地方,如果让你优化收集方法,有什么思路?

6.GC收集器有哪些?CMS收集器与G1收集器的特点。

7.Minor GC与Full GC分别在什么时候发生?

8.几种常用的内存调试工具:jmap、jstack、jconsole、jhat

9.JVM内存分哪几个区,每个区的作用是什么?

10.如何判断一个对象是否存活?(或者GC对象的判定方法)

11.简述 java垃圾回收机制? java中垃圾收集的方法有哪些?

JVM图谱展示

Mysql

1.数据库三范式是什么?MySQL中有哪些不同的表格?

2.有哪些数据库优化方面的经验 ?

3.请简述常用的索引有哪些种类?

4.简述在MySQ数据库中MyISAM和InnoDB的区别。

5.MySQL中InnoDB支持的四种事务隔离级别名称,以及逐级之间的区别?

6.CHAR和VARCHAR的区别?

7.TokuDB( Fractal Tree-节点带数据)

8.简单说一说drop、delete与truncate的区别。

9.什么是视图?什么是内联接、左外联接、右外联接?

10.事务隔离级别有哪些?MySQL的默认隔离级别是?

11.MySQL_fetch_array和MySQL_fetch_object的区别是什么?

12.MySQL数据库作发布系统的存储,一天五万条以上的增量,预计运维三年,怎么优化?

Tomcat

1.Tomcat的缺省端口是多少,怎么修改?

2.Tomcat有哪几种Connector运行模式(优化)?

3.Tomcat有几种部署方式?

4.Tomcat容器是如何创建servlet 类实例?用到了什么原理?

5.Tomcat工作模式?

6.内存调优,垃圾回收策略调优

Nginx

1.什么是Nginx?列 Nginx的一些特性。

2.列举Nginx和Apache之间的不同点,解释Nginx如何处理HTTP请求。

3.在Nginx中,如何使用未定义的服务器名称来阻止处理请求?

4.使用“反向代理服务器”的优点是什么?

5.列举Nginx服务器的最佳用途。

6.解释Nginx服务器上的Master和Worker进程分别是什么?

7.解释你如何通过不同于80的端口开启Nginx?

8.解释是否有可能将Nginx的错误替换为502错误、503?

9.在Nginx中,解释如何在URL中保留双斜线?

10.解释ngx_http_upstream_module的作用是什么?

11.解释如何在Nginx服务器上添加模块?

三、并发编程专题

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

2.获取对象的锁,这 个“ 锁“到底是什么 ? 如何确定对象的锁 ?

3.什么是可重入性,为什么说Synchronized是可重入锁 ?

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

5.为什么说Synchronized是非公平锁?

6.为什么说Synchronized是一个悲观锁?乐观锁的实现原理又是什么?什么是CAS,它有什么特性?

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

8.在 java中wait和sleep方法的不同?

9.用Java编程一个会导致死锁的程序,你将怎么解决?

10.什么是原子操作,Java中的原子操作是什么?

11.Java中的volatile关键是什么作用?怎样使用它?在Java中它跟synchronized方法有什么不同?

12.为什么我们调用start()方法时会执行run()方法,为什么我们不能直接调用run()方法?

13.Java中你怎样唤醒一个阻塞的线程?

14.在Java中CycliBarriar和CountdownLatch有什么区别?

15.你在多线程环境中遇到的常见的问题是什么?你是怎么解决它的?

四、框架源码系列

Spring IOC

1.Spring IOC如何实现?什么是Spring IOC容器?

2.IOC的优点是什么?

3.有哪些不同类型的IOC(依赖注入)方式?什么是依赖注入?

4.哪种依赖注入方式你建议使用,构造器注入,还是Setter方法注入?

5.Spring中有多少种IOC容器?

6.Spring IoC的实现机制。

7.Spring Bean的生命周期。

8.Bean Factory和Application Context有什么区别?

9.Spring应用程序有哪些不同组件?

10.什么是spring的内部bean?

11.什么是基于注解的容器配置?如何在spring中启动注解装配?

12.Spring支持哪些ORM框架?

.........

 

Spring Aop

1.Spring AOP实现原理,什么是Aspect?

2.动态代理(cglib 与 JDK)AOP有哪些实现方式?

3.Spring事务底层原理是什么?如何自定义注解实现功能?

4.什么是切点(JoinPoint)?么是通知(Advice)? 有哪些类型的通知(Advice)?

5.指出在Spring Aop中concern和cross-cutting concern的不同之处。

 

Spring MVC

1.Spring MVC框架有什么用?描述一下DispatcherServlet的工作流程。

2.介绍一下Web Application Context。

3.SpringMvc的控制器是不是单例模式,如果是,有什么问题,怎么解决?

4.SpingMvc中的控制器的注解一般用哪个,有没有别的注解可以替代?

5.@RequestMapping注解用在类上面有什么作用?

6.如果在拦截请求中,我想拦截get方式提交的方法,怎么配置?

7.SpringMvc中函数的返回值是什么?SpringMVC怎么样设定重定向和转发的?

8.SpringMvc中有个类把视图和数据都合并的一起的,叫什么?

9.怎么样把ModelMap里面的数据放入Session里面?SpringMvc怎么和AJAX相互调用的?

 

Mybatis

1.什么是 MyBatis?讲下MyBatis的缓存。

2.Mybatis是如何进行分页的?分页插件的原理是什么?

3.简述Mybatis的插件运行原理,以及如何编写一个插件?

4.Mybatis动态sql是做什么的?都有哪些动态sql?能简述一下动态sql的执行原理不?

5.#{}和${}的区别是什么?

6.为什么说Mybatis是半自动ORM映射工具?它与全自动的区别在哪里?

7.Mybatis是否支持延迟加载?如果支持,它的实现原理是什么?

8.MyBatis与Hibernate有哪些不同?

9.简述Mybatis的Xml映射文件和Mybatis内部数据结构之间的映射关系?

10.MyBatis里面的动态Sql是怎么设定的?用什么语法?

mybatis脑图展示

五、分布式专题

Redis

  1. 简述什么是Redis?
  2. Redis的数据类型?使用Redis有哪些好处?
  3. Redis相比Memcached有哪些优势?
  4. Memcache与Redis的区别都有哪些?
  5. Redis是单进程单线程的?一个字符串类型的值能存储最大容量是多少?
  6. Redis的持久化机制是什么?各自的优缺点?
  7. Redis过期键的删除策略?Redis的回收策略(淘汰策略)?
  8. 为什么Redis需要把所有数据放到内存中?
  9. Redis的同步机制了解么?Pipeline有什么好处,为什么要用pipeline?
  10. Redis集群方案什么情况下会导致整个集群不可用?
  11. Jedis与Redisson对比有什么优缺点?

 

Kafka

1.Kafka的设计时什么样的呢?

2.数据传输的事物定义有哪三种?

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

4.producer是否直接将数据发送到broker的leader(主节点)?

5.Kafa consumer是否可以消费指定分区消息?

6.Kafka消息是采用Pull模式,还是Push模式?

7.Kafka存储在硬盘上的消息格式是什么?

8.Kafka高效文件存储设计特点,Kafka与传统消息系统之间有哪三个关键区别?

9.partition的数据如何保存到硬盘。

10.Kafka的消费者如何消费数据?消费者负载均衡策略。

Netty

1.Netty原理,Netty高性能。

2.Netty RPC实现,RMI实现方式。

3.Protoclol Buffer,Thrift。

4.Netty的线程模型?

5.TCP粘包/拆包的原因及解决方法?

6.了解哪几种序列化协议?如何选择序列化协议?

7.Netty 的零拷贝实现?Netty的高性能表现在哪些方面?

8.NIOEventLoopGroup源码?

Dubbo

1.为什么要用Dubbo?Dubbo的整体架构设计有哪些分层?

2.默认使用的是什么通信框架,还有别的选择吗?服务调用是阻塞的吗?

3.一般使用什么注册中心?还有别的选择吗?

4.默认使用什么序列化框架,你知道的还有哪些?

5.服务提供者能实现失效提出是什么原理?

6.说说核心的配置有哪些?

7.同一个服务多个注册的情况下可以直连某一个服务吗?

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

9.Dubbo框架设计一共划分了哪10个层?

 

ZooKeeper

1.Zookeeper保证了哪些分布式一致性特性?

2.ZAB协议是什么?四种类型的数据节点Znode。

3.zk的配置管理(文件系统、通知机制)zk的命名服务(文件系统)。

4.Zookeeper集群管理(文件系统、通知机制)Zookeeper分布式锁(文件系统、通知机制)。

5.Zookeeper队列管理(文件系统、通知机制)Zookeeper数据复制。

6.zookeeper是如何保证事务的顺序一致性的?

RabbitMQ

1.RabbitMQ中的broker是指什么?cluster又是指什么?

2.什么是元数据?元数据分为哪些类型?包括哪些内容?与cluster相关的元数据有哪些?元数据是如何保存的?元数据在cluster中是如何分布的?

3.RAM node和disk node的区别?

4.RabbitMQ概念里的channel、exchange和queue这些东东是逻辑概念,还是对应着进程实体?这些东东分别起什么作用?

5.vhost是什么?起什么作用?

6.客户端连接到cluster中的任意node上是否都能正常工作?

7.能够在地理上分开的不同数据中心使用RabbitMQ cluster么?

8.如何确保消息正确地发送至 RabbitMQ? 如何确保消息接收方消费了消息?

六、微服务专题

Spring Boot

1.什么是Spring Boot?

2.Spring Boot有哪些优点?

3.什么是JavaConfig?

4.如何重新加载Spring Boot上的更改,而无需重新启动服务器?

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

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

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

8.如何使用Spring Boot实现分页和排序?

Spring Cloud

1.什么是Spring Cloud?使用Spring Cloud有什么优势?

2.服务注册和发现是什么意思?Spring Cloud如何实现?

3.负载平衡的意义什么?什么是Hystrix?它如何实现容错?

4.什么是Hystrix 断路器?我们需要它吗?什么是Netflix Feign?它的优点是什么?

5.什么是Spring Cloud Bus?我们需要它吗?

数据结构

1.栈(stack)队列(queue)链表(Link)散列表(Hash Table)。

2.排序二叉树、插入操作、删除操作、查询操作。

3.红黑树、左旋、右旋、添加、删除、B-TREE、位图。

4.加密算法

最后

考虑篇幅,就着重挑了一些常见的重要的面试题展示出来了。
所有的面试题目都不是一成不变的,上面的面试题只是给大家一个借鉴作用,最主要的是给自己增加知识的储备,有备无患。

 

 

资料获取方式:关注小编+转发文章+添加VX:Mxy98811即可免费获取

预祝在即将到来的2021年,想要涨薪的你们,顺利涨薪,想要跳槽的小伙伴拿到心仪offer!
2021年!不去追逐,永远不会拥有。不往前走,只会永远原地停留。2021冲冲冲