写点什么

疫情闭关期间,读完这些“Java 技术栈”,拿下阿里 Offer 没问题

作者:Geek_c72458
  • 2022 年 10 月 10 日
    湖南
  • 本文字数:4154 字

    阅读完需:约 14 分钟

又逢“金九银十”,年轻的毕业生们满怀希望与忐忑,去寻找、竞争一个工作机会。已经在职的开发同学,也想通过社会招聘或者内推的时机争取到更好的待遇、更大的平台。


然而,面试人群众多,技术市场却相对冷淡,面试的同学们不得不面临着 1 个职位 N 个应聘者的巨大竞争。


问:在这种现状下,如何才能收获又多又好的 Offer?


答:短期准备——刷面试题;长期筹谋——巩固核心技能。


面试题怎么刷?刷高频题、有深度的题、符合时效性的题。


核心技能如何巩固?先深入理解原理,再系统应用到实践。


今天,要分享的这些是非常干货的面试知识,在疫情闭关期间,这些“Java 技术栈”读完,斩获 offer 到手软。

一、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 负载均衡区别

  • ......


总结

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


需要文章中配套资料的朋友可以——点击传送门

用户头像

Geek_c72458

关注

还未添加个人签名 2022.09.20 加入

还未添加个人简介

评论

发布
暂无评论
疫情闭关期间,读完这些“Java技术栈”,拿下阿里Offer没问题_Java_Geek_c72458_InfoQ写作社区