2022年Java后端面试题整理-程序员宅基地

技术标签: Java  面试  经验分享  java  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.加密算法

最后

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

小伙伴们有兴趣想了解内容和更多相关学习资料的请点赞收藏+评论转发+关注我,后面会有很多干货。
我有一些面试题、架构、设计类资料可以说是程序员面试必备!所有资料都整理到网盘了,需要的话欢迎下载!私信我回复【07】即可免费获取

 

 

 

 

版权声明:本文为博主原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。
本文链接:https://blog.csdn.net/m0_70565884/article/details/124750972

智能推荐

python做数据透视表_利用Python进行数据分组/数据透视表-程序员宅基地

文章浏览阅读870次。1.数据分组源数据表如下所示:1.1 分组键是列名分组键是列名时直接将某一列或多列的列名传给groupby()方法,groupby()方法就会按照这一列或多列进行分组。按照一列进行分组import pandas as pddf = pd.DataFrame(pd.read_excel("Client_Data.xlsx"))print(df)#按照客户分类对数据进行分组print (df.grou..._python 透视数据对分组单元格进行运算

云原生Kubernetes:简化K8S应用部署工具Helm_helm image build-程序员宅基地

文章浏览阅读1k次。HELM有点类似于 Ubuntu 中的 APT 或 CentOS 中的 YUM。Charts是创建 Kubernetes 应用实例的信息集合,也就是一个 helm 的程序包,它包含了运行一个 k8s 应用所有需要的镜像、依赖关系和资源定义等,必要时还会包含 Service 资源定义,它类似于 yum 的 rpm 文件。HELM v3版本与v2版本的架构变化1. 最大的改动就是移除了 Tiller 组件,所有功能都通过 Helm CLI 与 ApiServer 直接交互。_helm image build

一、antd简介-程序员宅基地

文章浏览阅读4.8w次,点赞6次,收藏35次。版本:v3.26.3react系列有一大堆的组件,可以在ant design官网的,社区精选组件里面看到一、简介antd 是基于 Ant Design 设计体系的 React UI 组件库,主要用于研发企业级中后台产品。 Ant Design:用空格分隔的首字母大写单词,指代设计语言。 antd:全小写,指代 React UI 组件库。 ant.design:特指 ant.design 网站网址。安装:npm install antd --save使用组._antd

Spring中事务与aop的先后顺序问题-程序员宅基地

文章浏览阅读406次。Spring中的事务是通过aop来实现的,当我们自己写aop拦截的时候,会遇到跟spring的事务aop执行的先后顺序问题,比如说动态切换数据源的问题,如果事务在前,数据源切换在后,会导致数据源切换失效,所以就用到了Order(排序)这个关键字. 我们可以通过在..._spring aop和事务顺序

vue 组件封装 按钮button 支持点击按钮带阴影效果和Loading加载效果_vue u-button 加阴影-程序员宅基地

文章浏览阅读7.4k次。一,子组件shadowButton<template> <!-- 此组件支持自定义按钮文字和自定义按钮图片 --> <button :style="{backgroundColor:btnBgc,color:btnColor,width:width,height:height,fontSize:fontSize,boxShadow:boxShado..._vue u-button 加阴影

hibernate查询时出现LazyInitializationException异常的解决办法_查询对象有hibernatelazyinitializer-程序员宅基地

文章浏览阅读403次。一般是访问的属性被代理,无法获取到对应的值,解决方式:重新获取该对象的持久化对象访问属性即可。 比如获取用户的用户组public List getUserGroups(User user) { List list = new ArrayList<>(); if(user != null) { try {_查询对象有hibernatelazyinitializer

随便推点

PHP手写MVC (五)—— 路由-程序员宅基地

文章浏览阅读399次,点赞4次,收藏10次。路由是一个框架中必不可少的组件,其作用是把 URL 按照预定规则解析到特定控制器中。我们在这里定义了两种路由规则:查询字符串。在路径后面使用问号加参数,多个参数用 & 分隔。在配置文件使用 querystring 表示#控制器/方法?参数1=值1&参数2=值2http://domain/user/info?name=php&chapter=10路径...

类Unix系统(经常被称为UN*X或*nix)-程序员宅基地

文章浏览阅读308次。九号计划:Unix的后继者,采用UNIX设计与哲学,但更一致地套用至整个分布式系统,功能上并不完全相同。许多旨在为商业用户提供学术用户可用的功能的闭源。这些系统在很大程度上取代了私有副本。这些系统间日益增长的不兼容性导致了包括。进行商业二进制分许可时,出现了许多基于此的闭源系统,包括。衍生出的分布式操作系统,原本由贝尔实验室开发,现在被。的特性,有许多相似处,并且都在一定程度上遵守。- 全部重写,没有UNIX相关的代码。年代出现了各种自由、低成本和不受限的。标准,因此这些变体被成为。386BSD及其子類(_类unix

Could not open /dev/vmmon: No such file or directory. Please make sure that the kerne-程序员宅基地

文章浏览阅读5.2k次。启动虚拟机显示错误Could not open /dev/vmmon: No such file or directory. Please make sure that the kernel module `vmmon' is loaded.Failed to initialize monitor device.背景:Ubuntu16.04系统电脑上安装的vmware启动显示错误。..._could not open /dev/vmmon: no such file or directory. please make sure that

完美解决 matplotlib 对数上标负号乱码的问题_matplotlib负数对数轴-程序员宅基地

文章浏览阅读2.8k次,点赞11次,收藏16次。1.问题描述在matplotlib中显示中文标题时会出现乱码的问题,关于中文字体的调整见https://blog.csdn.net/txh3093/article/details/106858041但上述操作后仍然会在绘制对数图像时,对数刻度上标为负时的负号会出现乱码。本文将给出解决该问题的永久方案。2.解决方法最近发现有大佬在其他论坛中给出了解决方案,但讲述的有一点复杂,在此直接给出解决方案。通过everything软件搜索mathtext.py,一般在site-packages文_matplotlib负数对数轴

5.布局设计_布局包含设计吗-程序员宅基地

文章浏览阅读601次。在界面设计中,一个容器要放置许多组件,为了美观,为组件安排在容器中的位置,这就是布局设计。java.awt中定义了多种布局类,每种布局类对应一种布局的策略。常用的有以下布局类:FlowLayout,依次放置组件。BoarderLayout,将组件放置在边界上。CardLayout,将组件像扑克牌一样叠放,而每次只能显示其中一个组件。GridLayout,将显示区域按行、列划分成一个个相等的_布局包含设计吗

《Python学习》--- 基础部分_python轮廓提取的数据怎么让他从右到左-程序员宅基地

文章浏览阅读264次。学习笔记1:《Python从实践到入门》一:基础知识1:起步_python轮廓提取的数据怎么让他从右到左

推荐文章

热门文章

相关标签