Java 常见面试题整理

操作系统

  • 说一下线程和进程,它们的区别
  • 同步和异步的区别
  • 阻塞和非阻塞的区别
  • 操作系统中死锁的四个必要条件
  • mmap和普通文件读写的区别,mmap的注意点
  • CPU密集型和IO密集型的区别

Linux

  • linux 用过的命令
  • kill 用法,某个进程杀不掉的原因(进入内核态,忽略 kill 信号)
  • 系统管理命令(如查看内存- 网络情况)
  • 管道的使用
  • grep 的使用,一定要掌握,每次都会问在文件中查找
  • shell 脚本
  • find 命令
  • awk 使用
  • 讲一下linux的Swap分区
  • 硬链接和软连接区别
  • 讲一下epoll的基本原理,优点
  • 讲一下内核态与用户态,为什么要有用户态和内核态,如何切换
  • 讲一下五种IO模型

计算机网络

  • 网络为什么要分层
  • 为什么有IP地址还需要MAC地址
  • IP 地址子网划分
  • DNS 解析过程
  • URI和URL区别
  • 说一下 TCP 和 UDP 的区别,优缺点
  • TCP如何保证可靠传输?怎么做到不丢,不重,不漏(三次握手、滑动窗口、流量控制、拥塞控制)
  • TCP三次握手、TCP四次挥手
  • TCP粘包和拆包产生的原因?解决策略?
  • 谈一下你对 HTTP 的理解?
  • http2 比1.1主要改进了什么,有什么好的办法解决头部阻塞嘛?
  • 既然说 HTTP 是无状态的,那服务器怎么记住上次请求的用户?
  • GET和POST区别
  • 讲一下你熟悉的HTTP状态码,它们的含义是什么?
  • 讲一下一次完整的HTTP请求过程
  • HTTPS和HTTP的区别,https是如何保证数据传输的安全?
  • Session 和 Cookie 区别?

设计模式

  • 说一下你熟悉的设计模式?
  • 简单工厂和抽象工厂有什么区别?
  • 什么是单例模式?在什么情况下需要使用单例模式?

Java基础系列

容器

  • Collection 和 Collections 有什么区别?
  • List、Set、Map 之间的区别是什么?
  • ArrayList初始化默认长度、扩容、拷贝、增加和删除时间复杂度和空间复杂度
  • ArrayList 是一个线程安全的集合类吗?
  • ArrayList 和 LinkedList 的区别是什么?
  • 如何实现数组和 List 之间的转换?
  • ArrayList 和 Vector 的区别是什么?
  • 迭代器 Iterator 是什么?怎么使用?有什么特点?
  • 在 Queue 中 poll()和 remove()有什么区别?
  • 说一下 HashMap 的底层数据结构?
  • HashMap 和 Hashtable 有什么区别?
  • 如何决定使用 HashMap 还是 TreeMap?
  • HashMap 存储元素时 key 完全一样该怎么处理?
  • HashMap 的默认长度是多少?如何扩容的?
  • Hash 会有什么问题 ?怎么避免或者减少哈希碰撞 ?
  • JDK 1.8 的 HashMap 有什么变化?为什么 JDK 1.7 是头插法,JDK 1.8 是尾插法?
  • ConcurrentHashMap 和 HashMap 的区别?为什么 ConcurrentHashMap 会线程安全?
  • ConcurrentHashMap 虽然是线程安全的,但它也存在什么问题?
  • 了解 TreeMap 吗?TreeMap 最大的特点是什么?为什么已经有了 HashMap 了还要有 TreeMap 类?
  • 说一下 Fail-Fast 机制,结合源码说一下
  • 哪些集合类是线程安全的?
  • 怎么确保一个集合不能被修改?
  • 判断一个集合类是否为线程安全的机制是什么?

多线程

  • 线程有哪些状态?
  • 并行和并发有什么区别?
  • 线程和进程的区别?
  • 守护线程是什么?
  • 创建线程有哪几种方式?
  • 说一下 runnable 和 callable 有什么区别?
  • sleep() 和 wait() 有什么区别?
  • notify()和 notifyAll()有什么区别?
  • 为什么线程通信的方法wait(), notify()和notifyAll()被定义在Object类里?
  • 线程的 run()和 start()有什么区别?
  • 什么是线程安全?在 java 程序中怎么保证多线程的运行安全?
  • 锁的升级原理是什么?
  • 对象锁和静态锁之间的区别
  • 什么是死锁?怎么防止死锁?
  • ThreadLocal 是什么?有哪些使用场景?
  • 说一下 synchronized 底层实现原理?
  • synchronized 和 volatile 的区别是什么?
  • synchronized 和 Lock 有什么区别?
  • synchronized 和 ReentrantLock 区别是什么?
  • 说一下 atomic 的原理?
  • CAS是什么?缺点
  • 说一下 AQS的原理?
  • 如何停止一个线程?
  • final域的内存语义

线程池

  • 线程池的实现原理,为什么要用线程池
  • 线程池中Executor、ExecuteService、Executors 的区别
  • 线程池都有哪些状态?
  • 线程池中 submit()和 execute()方法有什么区别?
  • 线程池都有哪几种工作队列?
  • 怎么理解无界队列和有界队列?
  • ThreadPoolExecutor执行的策略
  • 说说几种常见的线程池及使用场景?特点?为什么不推荐通过Executors直接创建线程池
  • 四种拒绝策略
  • 线程池ThreadPoolExecutor参数如何设置
  • 单机上一个线程池正在处理服务,如果忽然断电了怎么办(正在处理和阻塞队列里的请求怎么处理)?

反射

  • 什么是反射?
  • 什么是 Java 序列化?什么情况下需要序列化?
  • 动态代理是什么?有哪些应用?
  • 怎么实现动态代理?

对象拷贝

  • 为什么要使用克隆?
  • 如何实现对象克隆?
  • 深拷贝和浅拷贝区别是什么?

异常

  • Java 异常的体系结构
  • throw 和 throws 的区别?
  • final、finally、finalize 有什么区别?
  • try-catch-finally 中哪个部分可以省略?
  • try-catch-finally 中,如果 catch 中 return 了,finally 还会执行吗?
  • 常见的异常类有哪些?

JVM

  • 说一下对jvm的理解,jvm的组成部分,各个部分的存储内容以及常见的jvm的问题排查步骤。
  • 对JVM熟不熟悉?简单说说类加载过程,里面执行的那些操作?
  • JVM方法区存储内容 是否会动态扩展 是否会出现内存溢出 出现的原因有哪些。
  • 介绍介绍CMS。
  • 介绍介绍G1。
  • 为什么jdk8用metaspace数据结构用来替代perm?
  • 简单谈谈堆外内存以及你的理解和认识。
  • JVM的内存模型的理解,threadlocal使用场景及注意事项?
  • JVM老年代和新生代的比例?
  • jstack,jmap,jutil分别的意义?如何线上排查JVM的相关问题?
  • Java虚拟机中,数据类型可以分为哪几类?
  • 怎么理解栈、堆?堆中存什么?栈中存什么?
  • 为什么要把堆和栈区分出来呢?栈中不是也可以存储数据吗?
  • 在Java中,什么是是栈的起始点,同是也是程序的起始点?
  • 为什么不把基本类型放堆中呢?
  • Java中的参数传递时传值呢?还是传引用?
  • Java中有没有指针的概念?
  • Java中,栈的大小通过什么参数来设置?
  • 一个空Object对象的占多大空间?
  • 对象引用类型分为哪几类?
  • 讲一讲垃圾回收算法。
  • 如何解决内存碎片的问题?
  • 如何解决同时存在的对象创建和对象回收问题?
  • 讲一讲内存分代及生命周期。
  • 什么情况下触发垃圾回收?
  • 如何选择合适的垃圾收集算法?
  • JVM中最大堆大小有没有限制?
  • 堆大小通过什么参数设置?
  • JVM有哪三种垃圾回收器?
  • 吞吐量优先选择什么垃圾回收器?响应时间优先呢?
  • 如何进行JVM调优?有哪些方法?
  • 如何理解内存泄漏问题?有哪些情况会导致内存泄露?如何解决?

MySQL

  • 说一下 ACID 是什么?
  • 说一下四种隔离级别,默认的隔离级别是什么,怎么避免不可重复读?
  • char 和 varchar 的区别是什么?
  • float 和 double 的区别是什么?
  • mysql 的内连接、左连接、右连接有什么区别?
  • mysql 索引是怎么实现的?
  • B+树索引和哈希索引的区别
  • B树和B+树的区别
  • 聚集索引和辅助索引
  • 什么情况下应不建或少建索引,导致索引失效的一些情况
  • key和index的区别
  • 怎么验证 mysql 的索引是否满足需求?
  • 说一下 mysql 常用的引擎?MyISAM和InnoDB的区别?如何选择?
  • 说一下 mysql 的行锁和表锁?
  • 锁的算法(Record Lock、Gap Lock、Next-Key Lock)
  • MySQL怎么实现redo log和binlog的一致性
  • 说一下乐观锁和悲观锁?
  • 说一下MySQL分区怎么实现,对业务层透明吗?MySQL支持的分区类型有哪些?使用场景?分区与分表的区别?
  • mysql主从同步原理
  • 说一下MVVC
  • mysql 问题排查都有哪些手段?
  • 如何做 mysql 的性能优化?

Netty

  • Netty为什么比NIO快?
  • 讲一下Netty零拷贝原理,为什么会有内核空间?怎么管理?
  • NIO一定比IO快吗?什么情况下会比IO慢?

Spring

  • 为什么要使用 spring?
  • 讲一下aop的实现原理?JDK动态代理和CGLIB代理的区别
  • 讲一下ioc的实现原理?
  • spring 有哪些主要模块?
  • spring 常用的注入方式有哪些?
  • spring 中的 bean 是线程安全的吗?
  • spring 支持几种 bean 的作用域?
  • spring 自动装配 bean 有哪些方式?
  • spring 事务实现方式有哪些?事务失效的几种原因
  • 说一下 spring 的事务隔离?
  • 说一下 spring mvc 运行流程?
  • spring mvc 有哪些组件?
  • @RequestMapping 的作用是什么?
  • @Autowired 的作用是什么?

Spring Boot

  • 什么是 Spring Boot?为什么要用 Spring Boot?和Spring有什么区别?
  • Spring Boot 核心配置文件是什么?
  • Spring Boot配置文件有哪几种类型?它们有什么区别?
  • Spring Boot 有哪些方式可以实现热部署?
  • 微服务怎么拆分
  • 讲一下DDD

MyBatis

  • mybatis的特性
  • mybatis的#号和$号有什么区别
  • mybatis如何进行类型转换
  • mybatis的xml有什么标签
  • mybatis底层如何加载mapper,以及SQL语句具体怎么执行
  • mybatis 有哪些执行器(Executor)?
  • mybatis 有几种分页方式?
  • RowBounds 是一次性查询全部结果吗?为什么?
  • mybatis 逻辑分页和物理分页的区别是什么?
  • mybatis 是否支持延迟加载?延迟加载的原理是什么?
  • MyBatis 如何处理批量请求?
  • 说一下 mybatis 的一级缓存和二级缓存?(高频)
  • mybatis 分页插件的实现原理是什么?
  • mybatis 如何编写一个自定义插件?

消息队列

  • 说说你使用过什么消息中间件?
  • 为什么要在系统里引入消息中间件?
  • 消息中间件技术选型为什么是RabbitMQ?技术选型的依据是什么?
  • 怎么保证消息中间件的高可用性?避免消息中间件故障后引发系统整体故障?
  • RabbitMQ的高可用性怎么实现。
  • 怎么保证投递出去的消息只有一条,不会出现重复的数据?
  • 消息重复是什么造成的,从生产端和消费端两个角度来考虑
  • 如何保证消息的顺序性?如果不需要保证消息顺序,为什么不需要?
  • 是否遇到过消息积压的生产故障?如果没遇到过,你考虑一下如何应对?
  • 说说RabbitMQ的底层架构原理,逻辑架构、物理架构以及数据持久化机制?
  • 你们RabbitMQ的最高峰QPS每秒是多少?线上如何部署的,部署了多少台机器,机器的配置如何?
  • 说说Kafka的底层架构原理,磁盘上数据如何存储的,整体分布式架构是如何实现的?
  • 说说Kafka是如何保证数据的高容错性的?零拷贝等技术是如何运用的?高吞吐量下如何优化生产者和消费者的性能?
  • 说说你对Kafka源码的理解?
  • RocketMQ的一个特点是对分布式事务的支持,说说他在分布式事务支持的底层原理?
  • RocketMQ的源码看过么,聊聊你对RocketMQ源码的理解?
  • 如果让你来动手实现一个分布式消息中间件,整体架构你会如何设计实现?

Redis

  • Redis 都有哪些数据类型?它们的内部数据结构是什么?分别在哪些场景下使用比较合适?
  • Redis有人说是单线程和有人说是多线程,你怎么看?Redis 为什么是单线程的?
  • Redis 和 Memcached 有什么区别?为什么单线程的 Redis 比多线程的 Memcached 效率要高得多?
  • Redis 的线程模型是什么?讲一下多路I/O复用模型?
  • Redis主从复制是怎么实现的
  • 什么是 Redis 的雪崩和穿透?Redis 崩溃之后会怎么样?系统该如何应对这种情况?如何处理 Redis 的穿透?
  • Redis 的持久化有哪几种方式?区别?持久化机制具体底层是如何实现的?
  • redis 支持的 java 客户端都有哪些?jedis 和 redisson 有哪些区别?
  • 如何保证缓存与数据库的双写一致性?
  • Redis 的并发竞争问题是什么?如何解决?了解 Redis 事务的 CAS 方案吗?
  • Redis 集群模式的工作原理?Redis 的 key 是如何寻址的?分布式寻址都有哪些算法?了解一致性 hash 算法吗?如何动态增加和删除一个节点?
  • Redis 怎么实现分布式锁?有什么缺陷?
  • Redis 如何做内存优化?
  • Redis 设置过期时间的原理?
  • Redis 淘汰策略有哪些?
  • Redis 常见的性能问题有哪些?该如何解决?
  • Redis 和MySQL区别,MySQL也有存储文档格式的存储引擎Memory,它们什么区别?

Zookeeper

  • raft协议相比paxos的优劣

Nginx

  • 讲一下nginx负载均衡,优势,Apache和Nginx区别
  • cgi和fastcgi区别
  • Nginx架构、模块关系、accept_mutex的实现以及多进程的负载均衡
  • nginx部署的时候出现502了吗,500什么时候出现的
  • Nginx负载均衡导致用户两次调用服务不在一个IP上,怎么保持连接

MongoDB

  • MongoDB和MySQL区别,MySQL也有存储文档格式的存储引擎Archive,它们什么区别?

Solr

  • Solr全量索引的时候发现数据有丢失,怎么处理?
  • Solr地理位置搜索的原理是什么?
  • 倒排索引的优势?

你可能感兴趣的:(Java 常见面试题整理)