今天,要分享的这些是非常干货的面试知识,在疫情闭关期间,这些“Java技术栈”读完,斩获offer到手软。(由于文章篇幅有限,完整的面试PDF文档,可以点击此处来获取就可以了!)
一、Java必备技术栈之基础篇
01 Java筑基面试题(一):Tomcat+Mysql+设计模式
- Tomcat 的缺省端口是多少,怎么修改?
- Tomcat 有哪几种 Connector 运行模式(优化)?
- Tomcat 有几种部署方式?
- Tomcat 容器是如何创建 servlet 类实例?用到了什么原理?
- Tomcat 如何优化?
- 内存调优
- 垃圾回收策略调优
- 共享 session 处理
- 数据库三范式是什么?
- 有哪些数据库优化方面的经验?
- 请简述常用的索引有哪些种类?
- 以及在 mysql 数据库中索引的工作机制是什么?
- MySQL 的基础操作命令
- mysql 的复制原理以及流程。
- mysql 支持的复制类型?
- mysql 中 myisam 与 innodb 的区别?
- 请列举出在 JDK 中几个常用的设计模式?
- 什么是设计模式?你是否在你的代码里面使用过任何设计模式?
- Java 中什么叫单例设计模式?请用 Java 写出线程安全的单例模式
- 在 Java 中,什么叫观察者设计模式(observer design pattern)?
- 使用工厂模式最主要的好处是什么?在哪里使用?
- 举一个用 Java 实现的装饰模式(decorator design pattern)?它是作用于对象层次还是类层次?
- 在 Java 中,为什么不允许从静态方法中访问非静态变量?
- 设计一个 ATM 机,请说出你的设计思路?
- ......
02 Java筑基面试题(二):并发+Netty+JVM
- 现在有 T1、T2、T3 三个线程,你怎样保证 T2 在 T1 执行完后执行,T3 在 T2 执行完后执行?
- 在 Java 中 Lock 接口比 synchronized 块的优势是什么?你需要实现一个高效的缓存,它允许多个用户读,但只允许一个用户写,以此来保持它的完整性,你会怎样去实现它?
- 在 java 中 wait 和 sleep 方法的不同?
- 用 Java 实现阻塞队列。
- 用 Java 写代码来解决生产者——消费者问题。
- 用 Java 编程一个会导致死锁的程序,你将怎么解决?
- 什么是原子操作,Java 中的原子操作是什么?
- Java 中的 volatile 关键是什么作用?怎样使用它?在 Java 中它跟 synchronized 方法有什么不同?
- 什么是竞争条件?你怎样发现和解决竞争?
- 你将如何使用 threaddump?你将如何分析 Thread dump?
- BIO、NIO 和 AIO 的区别?
- NIO 的组成?
- Netty 的特点?
- Netty 的线程模型?
- TCP 粘包/拆包的原因及解决方法?
- 了解哪几种序列化协议?
- 如何选择序列化协议?
- Netty 的零拷贝实现?
- Netty 的高性能表现在哪些方面?
- 内存模型以及分区,需要详细到每个区放什么?
- 堆里面的分区:Eden,survival (from+ to),老年代,各自的特点。
- 对象创建方法,对象的内存分配,对象的访问定位。
- GC 的两种判定方法
- SafePoint 是什么
- GC 的三种收集方法:标记清除、标记整理、复制算法的原理与特点,分别用在什么地方,如果让你优化收集方法,有什么思路?
- GC 收集器有哪些?CMS 收集器与 G1 收集器的特点。
- Minor GC 与 Full GC 分别在什么时候发生?
- .JVM 内存分哪几个区,每个区的作用是什么?
- ......
03 深入剖析Tomcat
04 Netty实战
二、Java必备技术栈之进阶篇
01 Spring 系列面试题(Spring+SpringBoot+SpringCloud+SpringMVC)
- 什么是 Spring 框架?Spring 框架有哪些主要模块
- 使用 Spring 框架能带来哪些好处?
- 什么是控制反转(IOC)?什么是依赖注入?
- 请解释下 Spring 框架中的 IoC?
- BeanFactory 和 ApplicationContext 有什么区别?
- Spring 有几种配置方式?
- 如何用基于 XML 配置的方式配置 Spring?
- 如何用基于 Java 配置的方式配置 Spring?
- ......
- 什么是 Spring Boot?
- Spring Boot 有哪些优点?
- 如何重新加载 Spring Boot 上的更改,而无需重新启动服务器?
- Spring Boot 中的监视器是什么?
- 如何在 Spring Boot 中禁用 Actuator 端点安全性?
- 如何在自定义端口上运行 Spring Boot 应用程序?
- 如何实现 Spring Boot 应用程序的安全性?
- 如何集成 Spring Boot 和 ActiveMQ?
- ......
- 什么是 Spring Cloud?
- 使用 Spring Cloud 有什么优势?
- 服务注册和发现是什么意思?Spring Cloud 如何实现?
- 负载平衡的意义什么?
- 什么是 Hystrix?它如何实现容错?
- 什么是 Hystrix 断路器?我们需要它吗?
- 什么是 Netflix Feign?它的优点是什么?
- ......
- 什么是 SpringMVC?
- SpringMVC 工作原理
- SpringMvc 的控制器是不是单例模式,如果是,有什么问题,怎么解决?
- 如果你也用过 struts2.简单介绍下 springMVC 和 struts2 的区别有哪些?
- SpingMvc 中的控制器的注解一般用那个,有没有别的注解可以替代?
02 面试必问并发编程高级面试专题
Synchronized 相关问题:
- Synchronized 用过吗?其原理是什么 ?
- 你刚才提到获取对象的锁,这个“锁”到底是什么 ?如何确定对象的锁?
- 什么是可重入性,为什么说Synchronized 是可重入锁?
- JVM对Java的原生锁做了哪些优化?
- 为什么说 Synchronized 是非公平锁?
- 什么是锁消除和锁粗化?
- 为什么说 Synchronized 是一个悲观锁?乐观锁的实现原理又是什么?什么是CAS,它有什么特性?
- 乐观锁一定就是好的吗?
可重入锁ReentrantLock 及其他显式锁相关问题:
- 跟 Synchronized 相 比 , 可重入锁 ReentrantLock 其实现原理有什么不 同 ?
- 那么请谈谈AQS 框架是怎么回事儿?
- 请尽可能详尽地对比下 Synchronized 和 ReentrantLock的异同。
- ReentrantLock 是如何实现可重入性的?
- 除了ReetrantLock, 你还接触过JUC 中的哪些并发工具?
- 请谈谈ReadWriteLock 和 StampedLock。
- 如何让Java 的线程彼此同步?你了解过哪些同步器?请分别介绍下 。
- CyclicBarrier 和 CountDownLatch 看起来很相似,请对比下呢?
Java 线程池相关问题:
- Java 中的线程池是如何实现的?
- 创建线程池的几个核心构造参数?
- 线程池中的线程是怎么创建的?是一开始就随着线程池的启动创建好的吗?
- 既然提到可以通过配置不同参数创建出不同的线程池,那么Java 中默认实现好的线程池又有哪些呢 ? 请比较它们的异同。
- 如何在Java 线程池中提交线程?
Java 内存模型相关问题:
- 什么是 Java 的内存模型,Java中各个线程是怎么彼此看到对方的变量的?
- 请谈谈volatile 有什么特点,为什么它能保证变量对所有线程的可见性?
- 既然 volatile 能够保证线程间的变量可见性,是不是就意味着基于volatile 变量的运算就是并发安全的?
- 请对比下 volatile 对比Synchronized的异同。
- 请谈谈 ThreadLocal 是怎么解决并发安全的。
- 很多人都说要慎用 ThreadLocal,谈谈你的理解,使用ThreadLocal 需要注意些什么?
03 分布式数据面试专题系列:Memcached+Redis+MongoDB
memcached 是怎么工作的?
memcached 最大的优势是什么?
memcached 和 MySQL 的 query cache 相比,有什么优缺点?
memcached 和服务器的 local cache(比如 PHP 的 APC、mmap 文件等)相比,有什么优缺点?
memcached 的 cache 机制是怎样的?
memcached 如何实现冗余机制?
memcached 如何处理容错的?
我需要把 memcached 中的 item 批量导出导入,怎么办?
......
redis 和 memcached 什么区别?为什么高并发下有时单线程的 redis 比多线程的memcached 效率要高?
redis 主从复制如何实现的?redis 的集群模式如何实现?redis 的 key 是如何寻址的?
使用 redis 如何设计分布式锁?说一下实现思路?使用 zk 可以吗?如何实现?这两种有什么区别?
知道 redis 的持久化吗?底层如何实现的?有什么优点缺点?
redis 过期策略都有哪些?LRU 算法知道吗?写一下 java 代码实现?
......
你说的 NoSQL 数据库是什么意思?NoSQL 与 RDBMS 直接有什么区别?为什么要使用和不使用NoSQL 数据库?说一说 NoSQL 数据库的几个优点?
NoSQL 数据库有哪些类型?
MySQL 与 MongoDB 之间最基本的差别是什么?
你怎么比较 MongoDB、CouchDB 及 CouchBase?
MongoDB 成为最好 NoSQL 数据库的原因是什么?
04 分布式通讯面试专题系列:ActiveMQ+RabbitMQ+Kafka
- 1.什么是 ActiveMQ?
- ActiveMQ 服务器宕机怎么办?
- 丢消息怎么办?
- ActiveMQ 中的消息重发时间间隔和重发次数吗?
- ......
- RabbitMQ 中的 broker 是指什么?cluster 又是指什么?
- 什么是元数据?元数据分为哪些类型?包括哪些内容?与 cluster 相关的元数据有哪些?元数据是如何保存的?元数据在 cluster 中是如何分布的?
- RAM node 和 disk node 的区别?
- RabbitMQ 上的一个 queue 中存放的 message 是否有数量限制?
- RabbitMQ 概念里的 channel、exchange 和 queue 这些东东是逻辑概念,还是对应着进程实体?这些东东分别起什么作用?
- vhost 是什么?起什么作用?
- 在单 node 系统和多 node 构成的 cluster 系统中声明 queue、exchange ,以及进行 binding 会有什么不同?
- 客户端连接到 cluster 中的任意 node 上是否都能正常工作?
- ......
- Kafka 的设计时什么样的呢?
- 数据传输的事物定义有哪三种?
- Kafka 判断一个节点是否还活着有那两个条件?
- producer 是否直接将数据发送到 broker 的 leader(主节点)?
- Kafa consumer 是否可以消费指定分区消息
- Kafka 消息是采用 Pull 模式,还是 Push 模式
- Kafka 存储在硬盘上的消息格式是什么?
- Kafka 高效文件存储设计特点:
- Kafka 与传统消息系统之间有三个关键区别
- Kafka 创建 Topic 时如何将分区放置到不同的 Broker 中
05 分布式限流面试专题系列:Nginx+zookeeper
- 请解释一下什么是 Nginx?
- 请列举 Nginx 的一些特性。
- 请列举 Nginx 和 Apache 之间的不同点
- 请解释 Nginx 如何处理 HTTP 请求
- 在 Nginx 中,如何使用未定义的服务器名称来阻止处理请求
- 使用“反向代理服务器”的优点是什么?
- 请列举 Nginx 服务器的最佳用途
- 请解释 Nginx 服务器上的 Master 和 Worker 进程分别是什么?
- 请解释是否有可能将 Nginx 的错误替换为 502 错误、503?
- ......
- ZooKeeper 是什么?
- ZooKeeper 提供了什么?
- zookeeper 是如何保证事务的顺序一致性的?
- zookeeper 是如何选取主 leader 的?
- 机器中为什么会有 leader?
- zk 节点宕机如何处理?
- zookeeper 负载均衡和 nginx 负载均衡区别
- ......
总结
疫情时期不要放松心态,在家更要自律学习。
现在抓紧时间,不用靠金三银四,也能找到好工作。
以上所有的面试题(含答案)、实战文档,学习笔记等PDF文档资料,均免费放送分享,需要的朋友可以点击此处来获取就可以了!