绞尽脑汁我掏空了各大搜索引擎,耗时10个月给你整理了209道Java面试题含答案,满满干货记得收藏再看

答案获取方式:


Java集合19题

这个算是java中的基础题吧,但是不要小看这些题,有一些可能都回答不上来。我发现最近关于底层问题问的越来越多了,这也算一个基本线吧,如果回答不上来就凉凉了。

  • ArrayList 和 Vector 的区别。
  • 说说 ArrayList,Vector, LinkedList 的存储性能和特性。
  • 快速失败 (fail-fast) 和安全失败 (fail-safe) 的区别是什么?
  • hashmap 的数据结构。
  • HashMap 的工作原理是什么?
  • Hashmap 什么时候进行扩容呢?
  • List、Map、Set 三个接口,存取元素时,各有什么特点?
  • Set 里的元素是不能重复的,那么用什么方法来区分重复与否呢? 是用 == 还是 equals()? 它们有何区别?
  • 两个对象值相同 (x.equals(y) == true),但却可有不同的 hash code,这句话对不对?
  • heap 和 stack 有什么区别。
  • Java 集合类框架的基本接口有哪些?
  • HashSet 和 TreeSet 有什么区别?
  • HashSet 的底层实现是什么?
  • LinkedHashMap 的实现原理?
  • 为什么集合类没有实现 Cloneable 和 Serializable 接口?
  • 什么是迭代器 (Iterator)?
  • Iterator 和 ListIterator 的区别是什么?
  • 数组 (Array) 和列表 (ArrayList) 有什么区别?什么时候应该使用 Array 而不是 ArrayList?
  • Java 集合类框架的最佳实践有哪些?

JVM与调优18题

JVM算是去大厂必会的一个知识点了,性能调优问题、垃圾回收机制、双亲委派以及体系结构,这些会的越多加分就越多。

  • Java 类加载过程?
  • 描述一下 JVM 加载 Class 文件的原理机制?
  • Java 内存分配。
  • GC 是什么? 为什么要有 GC?
  • 简述 Java 垃圾回收机制
  • 如何判断一个对象是否存活?(或者 GC 对象的判定方法)
  • 垃圾回收的优点和原理。并考虑 2 种回收机制
  • 垃圾回收器的基本原理是什么?垃圾回收器可以马上回收内存吗?有什么办法主动通知虚拟机进行垃圾回收?
  • Java 中会存在内存泄漏吗,请简单描述
  • 深拷贝和浅拷贝。
  • System.gc() 和 Runtime.gc() 会做什么事情?
  • finalize() 方法什么时候被调用?析构函数 (finalization) 的目的是什么?
  • 如果对象的引用被置为 null,垃圾收集器是否会立即释放对象占用的内存?
  • 串行(serial)收集器和吞吐量(throughput)收集器的区别是什么?
  • 在 Java 中,对象什么时候可以被垃圾回收?
  • 简述 Java 内存分配与回收策略以及 Minor GC 和 Major GC。
  • VM 的永久代中会发生垃圾回收么?

并发编程24题

并发是重点的重点,记得有一次面试关于并发问题面试官死磕了我半个小时,从锁机制到线程池被安排的明明白白的。

  • Synchronized 用过吗,其原理是什么?
  • 你刚才提到获取对象的锁,这个“锁”到底是什么?如何确定对象的锁?
  • 什么是可重入性,为什么说 Synchronized 是可重入锁?
  • VM 对 Java 的原生锁做了哪些优化?48
  • 为什么说 Synchronized 是非公平锁?49
  • 什么是锁消除和锁粗化?49
  • 为什么说 Synchronized 是一个悲观锁?乐观锁的实现原理又是什么?什么是 CAS,它有什么特性?
  • 乐观锁一定就是好的吗?
  • 跟 Synchronized 相比,可重入锁 ReentrantLock 其实现原理有什么不同?
  • 那么请谈谈 AQS 框架是怎么回事儿?
  • 请尽可能详尽地对比下 Synchronized 和 ReentrantLock 的异同。
  • ReentrantLock 是如何实现可重入性的?
  • 除了 ReetrantLock,你还接触过 JUC 中的哪些并发工具?
  • 请谈谈 ReadWriteLock 和 StampedLock。
  • 如何让 Java 的线程彼此同步?你了解过哪些同步器?请分别介绍下。
  • CyclicBarrier 和 CountDownLatch 看起来很相似,请对比下呢?
  • Java 线程池相关问题
  • Java 中的线程池是如何实现的?
  • 创建线程池的几个核心构造参数?
  • 线程池中的线程是怎么创建的?是一开始就随着线程池的启动创建好的吗?
  • 既然提到可以通过配置不同参数创建出不同的线程池,那么 Java 中默认实现好的线程池又有哪些呢?请比较它们的异同
  • 如何在 Java 线程池中提交线程?
  • 什么是 Java 的内存模型,Java 中各个线程是怎么彼此看到对方的变量的?
  • 请谈谈 volatile 有什么特点,为什么它能保证变量对所有线程的可见性?

spring 22题

我相信大家都用过Spring吧,身为开源框架他的重要性毋庸置疑,IOC、AOP两大必问核心,从注解到标签都有可能问到。

  • 1、什么是 Spring 框架?Spring 框架有哪些主要模块?
  • 2、使用 Spring 框架能带来哪些好处?
  • 3、什么是控制反转(IOC)?什么是依赖注入?
  • 4、请解释下 Spring 框架中的 IoC?
  • 5、BeanFactory 和 ApplicationContext 有什么区别?
  • 6、Spring 有几种配置方式?
  • 7、如何用基于 XML 配置的方式配置 Spring?
  • 8、如何用基于 Java 配置的方式配置 Spring?
  • 9、怎样用注解的方式配置 Spring?
  • 10、请解释 Spring Bean 的生命周期?
  • 11、Spring Bean 的作用域之间有什么区别?
  • 12、什么是 Spring inner beans?
  • 13、Spring 框架中的单例 Beans 是线程安全的么?
  • 14、请举例说明如何在 Spring 中注入一个 Java Collection?
  • 15、如何向 Spring Bean 中注入一个 Java.util.Properties?
  • 16、请解释 Spring Bean 的自动装配?
  • 17、请解释自动装配模式的区别?
  • 18、如何开启基于注解的自动装配?
  • 19、请举例解释@Required 注解?
  • 20、请举例解释@Autowired 注解?
  • 21、请举例说明@Qualifier 注解?
  • 22、构造方法注入和设值注入有什么区别?

设计模式 10题

记得最清楚的是单例模式的懒汉和饿汉模式,这个考察的方向是一般是固定的,当然不排除面试官考察通知工作中遇到的问题(同学就是这样,自己工作不会的就狂问应聘的,心疼面试人员)。

  • 1.请列举出在 JDK 中几个常用的设计模式?
  • 2.什么是设计模式?你是否在你的代码里面使用过任何设计模式?
  • 3.Java 中什么叫单例设计模式?请用 Java 写出线程安全的单例模式
  • 4.在 Java 中,什么叫观察者设计模式(observer design pattern)?
  • 5.使用工厂模式最主要的好处是什么?在哪里使用?
  • 6.举一个用 Java 实现的装饰模式(decorator design pattern)?它是作用于对象层次还是类
    层次?
  • 7.在 Java 中,为什么不允许从静态方法中访问非静态变量?
  • 8.设计一个 ATM 机,请说出你的设计思路?
  • 9.在 Java 中,什么时候用重载,什么时候用重写?
  • 10.举例说明什么情况下会更倾向于使用抽象类而不是接口

springboot 22题

最近springboot和springcloud的占比越来越重,因为他们最受中小企业欢迎,学会了它们最低也饿不死了哈哈。

  • 什么是 Spring Boot?
  • Spring Boot 有哪些优点?
  • 什么是 JavaConfig?
  • 如何重新加载 Spring Boot 上的更改,而无需重新启动服务器?
  • Spring Boot 中的监视器是什么?
  • 如何在 Spring Boot 中禁用 Actuator 端点安全性?
  • 如何在自定义端口上运行 Spring Boot 应用程序?
  • 什么是 YAML?
  • 如何实现 Spring Boot 应用程序的安全性?
  • 如何集成 Spring Boot 和 ActiveMQ?
  • 如何使用 Spring Boot 实现分页和排序?
  • 什么是 Swagger?你用 Spring Boot 实现了它吗?
  • 什么是 Spring Profiles?
  • 什么是 Spring Batch?
  • 什么是 FreeMarker 模板?
  • 如何使用 Spring Boot 实现异常处理?
  • 您使用了哪些 starter maven 依赖项?
  • 什么是 CSRF 攻击?
  • 什么是 WebSockets?
  • 什么是 AOP?
  • 什么是 Apache Kafka?
  • 我们如何监视所有 Spring Boot 微服务?

Spring Cloud 8题

  • 什么是 Spring Cloud?
  • 使用 Spring Cloud 有什么优势?
  • 服务注册和发现是什么意思?Spring Cloud 如何实现?
  • 负载平衡的意义什么?
  • 什么是 Hystrix?它如何实现容错?
  • 什么是 Hystrix 断路器?我们需要它吗?
  • 什么是 Netflix Feign?它的优点是什么?
  • 什么是 Spring Cloud Bus?我们需要它吗?

Redis 8题

Redis的数据特点以及回收策略是很重要的一部分,它的优势以及使用场景都需要了解一下

  • 什么是redis?
  • Reids的特点
  • Redis支持的数据类型
  • Redis是单进程单线程的
  • 虚拟内存
  • Redis锁
  • 读写分离模型
  • 数据分片模型

一线互联网企业精品面试题73道

  • junit 用法,before,beforeClass,after, afterClass 的执行顺序
  • 分布式锁
  • nginx 的请求转发算法,如何配置根据权重转发
  • 用 hashmap 实现 redis 有什么问题(死锁,死循环,可用 ConcurrentH ashmap)
  • 线程的状态
  • 线程的阻塞的方式
  • sleep 和 wait 的区别
  • hashmap 的底层实现
  • 一万个人抢 100 个红包,如何实现(不用队列),如何保证 2 个人不能抢到同一个红包,可用分布式锁
  • java 内存模型,垃圾回收机制,不可达算法
  • 两个 Integer 的引用对象传给一个 swap 方法在方法内部交换引用,返回后,两个引用的值是否会发现变化
  • aop 的底层实现,动态代理是如何动态,假如有 100 个对象,如何动态 的为这 100 个对象代理
  • 是否用过 maven install。 maven test。git(make install 是安装本地 jar 包)
  • tomcat 的各种配置,如何配置 docBase
  • spring 的 bean 配置的几种方式
  • web.xml 的配置
  • spring 的监听器。
  • zookeeper 的实现机制,有缓存,如何存储注册服务的
  • IO 会阻塞吗?readLine 是不是阻塞的
  • 用过 spring 的线程池还是 java 的线程池?
  • 字符串的格式化方法 (20,21 这两个问题问的太低级了)
  • 时间的格式化方法
  • 定时器用什么做的
  • 线程如何退出结束
  • java 有哪些锁?乐观锁 悲观锁 synchronized 可重入锁 读写锁,用过 reentrantlock 吗?reentrantlock 与 synmchronized 的区别
  • ThreadLocal 的使用场景
  • java 的内存模型,垃圾回收机制
  • 为什么线程执行要调用 start 而不是直接 run(直接 run,跟普通方法没 什么区别,先调 start,run 才会作为一个线程方法运行)
  • qmq 消息的实现机制(qmq 是去哪儿网自己封装的消息队列)
  • 遍历 hashmap 的三种方式
  • jvm 的一些命令31. memcache 和 redis 的区别
  • mysql 的行级锁加在哪个位置
  • ConcurrentHashmap 的锁是如何加的?是不是分段越多越好
  • myisam 和 innodb 的区别(innodb 是行级锁,myisam 是表级锁)
  • mysql 其他的性能优化方式
  • linux 系统日志在哪里看
  • 如何查看网络进程
  • 统计一个整数的二进制表示中 bit 为 1 的个数
  • jvm 内存模型,java 内存模型
  • 如何把 java 内存的数据全部 dump 出来
  • 如何手动触发全量回收垃圾,如何立即触发垃圾回收
  • hashmap 如果只有一个写其他全读会出什么问题
  • mybatis 如何映射表结构
  • 二叉树遍历
  • 主从复制
  • mysql 引擎区别
  • 静态内部类加载到了哪个区?方法区
  • class 文件编译后加载到了哪
  • web 的 http 请求如何整体响应时间变长导致处理的请求数变少,该如何处理?用队列,当处理不了那么多 http 请求时将请求放到队列中慢慢处理,web 如何实现队列77. 线程安全的单例模式
  • 快速排序性能考虑
  • volatile 关键字用法
  • 求表的 size,或做数据统计可用什么存储引擎
  • 读多写少可用什么引擎
  • 假如要统计多个表应该用什么引擎
  • concurrenhashmap 求 size 是如何加锁的,如果刚求完一段后这段发生了变化该如何处理1000 个苹果放 10 个篮子,怎么放,能让我拿到所有可能的个数可重入的读写锁,可重入是如何实现的?
  • 是否用过 NIO
  • java 的 concurrent 包用过没
  • sting s=new string("abc")分别在堆栈上新建了哪些对象
  • java 虚拟机的区域分配,各区分别存什么
  • 分布式事务(JTA)91. threadlocal 使用时注意的问题(ThreadLocal 和 Synchonized 都用于解决多线程并发访问。但是 ThreadLocal 与 synchronized 有本质的区别。s
  • ynchronized 是利用锁的机制,使变量或代码块在某一时该只能被一个线程访问。而 ThreadLocal 为每一个线程都提供了变量的副本,使得每个线程在某 一时间访问到的并不是同一个对象,这样就隔离了多个线程对数据的数据共享。而 Synchronized 却正好相反,它用于在多个线程间通信时能够获得数据共享)
  • java 有哪些容器(集合,tomcat 也是一种容器)
  • 二分查找算法
  • myisam 的优点,和 innodb 的区别
  • redis 能存哪些类型
  • http 协议格式,get 和 post 的区别
  • 可重入锁中对应的 wait 和 notify
  • redis 能把内存空间交换进磁盘中吗(这个应该是可以的,但是那个面试官 非跟我说不可以)
  • java 线程池中基于缓存和基于定长的两种线程池,当请求太多时分别是如何处理的?定长的事用的队列,如果队列也满了呢?交换进磁盘?基于缓存的 线程池解决方法呢?
  • synchronized 加在方法上用的什么锁101. 可重入锁中的 lock 和 trylock 的区别
  • innodb 对一行数据的读会枷锁吗?不枷锁,读实际读的是副本
  • redis 做缓存是分布式存的?不同的服务器上存的数据是否重复?guava

必考题和答案

 

答案获取方式

关注+点赞!

猜你喜欢

转载自blog.csdn.net/weixin_51204715/article/details/108963843