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

智能推荐

oracle 12c 集群安装后的检查_12c查看crs状态-程序员宅基地

文章浏览阅读1.6k次。安装配置gi、安装数据库软件、dbca建库见下:http://blog.csdn.net/kadwf123/article/details/784299611、检查集群节点及状态:[root@rac2 ~]# olsnodes -srac1 Activerac2 Activerac3 Activerac4 Active[root@rac2 ~]_12c查看crs状态

解决jupyter notebook无法找到虚拟环境的问题_jupyter没有pytorch环境-程序员宅基地

文章浏览阅读1.3w次,点赞45次,收藏99次。我个人用的是anaconda3的一个python集成环境,自带jupyter notebook,但在我打开jupyter notebook界面后,却找不到对应的虚拟环境,原来是jupyter notebook只是通用于下载anaconda时自带的环境,其他环境要想使用必须手动下载一些库:1.首先进入到自己创建的虚拟环境(pytorch是虚拟环境的名字)activate pytorch2.在该环境下下载这个库conda install ipykernelconda install nb__jupyter没有pytorch环境

国内安装scoop的保姆教程_scoop-cn-程序员宅基地

文章浏览阅读5.2k次,点赞19次,收藏28次。选择scoop纯属意外,也是无奈,因为电脑用户被锁了管理员权限,所有exe安装程序都无法安装,只可以用绿色软件,最后被我发现scoop,省去了到处下载XXX绿色版的烦恼,当然scoop里需要管理员权限的软件也跟我无缘了(譬如everything)。推荐添加dorado这个bucket镜像,里面很多中文软件,但是部分国外的软件下载地址在github,可能无法下载。以上两个是官方bucket的国内镜像,所有软件建议优先从这里下载。上面可以看到很多bucket以及软件数。如果官网登陆不了可以试一下以下方式。_scoop-cn

Element ui colorpicker在Vue中的使用_vue el-color-picker-程序员宅基地

文章浏览阅读4.5k次,点赞2次,收藏3次。首先要有一个color-picker组件 <el-color-picker v-model="headcolor"></el-color-picker>在data里面data() { return {headcolor: ’ #278add ’ //这里可以选择一个默认的颜色} }然后在你想要改变颜色的地方用v-bind绑定就好了,例如:这里的:sty..._vue el-color-picker

迅为iTOP-4412精英版之烧写内核移植后的镜像_exynos 4412 刷机-程序员宅基地

文章浏览阅读640次。基于芯片日益增长的问题,所以内核开发者们引入了新的方法,就是在内核中只保留函数,而数据则不包含,由用户(应用程序员)自己把数据按照规定的格式编写,并放在约定的地方,为了不占用过多的内存,还要求数据以根精简的方式编写。boot启动时,传参给内核,告诉内核设备树文件和kernel的位置,内核启动时根据地址去找到设备树文件,再利用专用的编译器去反编译dtb文件,将dtb还原成数据结构,以供驱动的函数去调用。firmware是三星的一个固件的设备信息,因为找不到固件,所以内核启动不成功。_exynos 4412 刷机

Linux系统配置jdk_linux配置jdk-程序员宅基地

文章浏览阅读2w次,点赞24次,收藏42次。Linux系统配置jdkLinux学习教程,Linux入门教程(超详细)_linux配置jdk

随便推点

matlab(4):特殊符号的输入_matlab微米怎么输入-程序员宅基地

文章浏览阅读3.3k次,点赞5次,收藏19次。xlabel('\delta');ylabel('AUC');具体符号的对照表参照下图:_matlab微米怎么输入

C语言程序设计-文件(打开与关闭、顺序、二进制读写)-程序员宅基地

文章浏览阅读119次。顺序读写指的是按照文件中数据的顺序进行读取或写入。对于文本文件,可以使用fgets、fputs、fscanf、fprintf等函数进行顺序读写。在C语言中,对文件的操作通常涉及文件的打开、读写以及关闭。文件的打开使用fopen函数,而关闭则使用fclose函数。在C语言中,可以使用fread和fwrite函数进行二进制读写。‍ Biaoge 于2024-03-09 23:51发布 阅读量:7 ️文章类型:【 C语言程序设计 】在C语言中,用于打开文件的函数是____,用于关闭文件的函数是____。

Touchdesigner自学笔记之三_touchdesigner怎么让一个模型跟着鼠标移动-程序员宅基地

文章浏览阅读3.4k次,点赞2次,收藏13次。跟随鼠标移动的粒子以grid(SOP)为partical(SOP)的资源模板,调整后连接【Geo组合+point spirit(MAT)】,在连接【feedback组合】适当调整。影响粒子动态的节点【metaball(SOP)+force(SOP)】添加mouse in(CHOP)鼠标位置到metaball的坐标,实现鼠标影响。..._touchdesigner怎么让一个模型跟着鼠标移动

【附源码】基于java的校园停车场管理系统的设计与实现61m0e9计算机毕设SSM_基于java技术的停车场管理系统实现与设计-程序员宅基地

文章浏览阅读178次。项目运行环境配置:Jdk1.8 + Tomcat7.0 + Mysql + HBuilderX(Webstorm也行)+ Eclispe(IntelliJ IDEA,Eclispe,MyEclispe,Sts都支持)。项目技术:Springboot + mybatis + Maven +mysql5.7或8.0+html+css+js等等组成,B/S模式 + Maven管理等等。环境需要1.运行环境:最好是java jdk 1.8,我们在这个平台上运行的。其他版本理论上也可以。_基于java技术的停车场管理系统实现与设计

Android系统播放器MediaPlayer源码分析_android多媒体播放源码分析 时序图-程序员宅基地

文章浏览阅读3.5k次。前言对于MediaPlayer播放器的源码分析内容相对来说比较多,会从Java-&amp;amp;gt;Jni-&amp;amp;gt;C/C++慢慢分析,后面会慢慢更新。另外,博客只作为自己学习记录的一种方式,对于其他的不过多的评论。MediaPlayerDemopublic class MainActivity extends AppCompatActivity implements SurfaceHolder.Cal..._android多媒体播放源码分析 时序图

java 数据结构与算法 ——快速排序法-程序员宅基地

文章浏览阅读2.4k次,点赞41次,收藏13次。java 数据结构与算法 ——快速排序法_快速排序法