时间紧促,我们直接上java技术栈!

一、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 机,请说出你的设计思路?
  • ......

文章篇幅有限,为了节约大家的宝贵时间,只能为大家展示部分内容。需要领取全部学习资源的朋友,麻烦帮忙一键三连一下这篇文章,然后加小助理VX:bjmsb10即可免费领取

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 负载均衡区别
  • ......

 

总结

疫情时期不要放松心态,在家更要自律学习。

现在抓紧时间,不用靠金三银四,也能找到好工作。

文章篇幅有限,为了节约大家的宝贵时间,只能为大家展示部分内容。需要领取全部学习资源的朋友,麻烦帮忙一键三连一下这篇文章,然后加小助理即可免费领取