程序员一步入中年,不知不觉便会被铺天盖地的“危机感”上身,曾经的那个少年已经不在,时间就是这样公平。就算你能发明Java语言,随着时间的推移,你注定还是要成为慢慢变蔫的茄子,缓缓变黑的葡萄。

看着金三银四来临的消息,吓得我周末赶紧拿出了面试资料,只读了一小部分我就发现一个事实,果然有很多的知识点都模棱两可,相信很多的人都跟我一样有这样的危机感。怎么办呢???

今天给大家分享一份阿里P9架构师推荐的Java后端领域巅峰之作《Java面试资源大礼包》,我看完这份PDF之后彻底颠覆了我对Java的认知。

架构师必备技能:(大厂面试必问)

​编辑

多线程&并发面试题:

JAVA 并发知识库:

​编辑

  • Java中实现多线程有几种方法
  • 继承Thread类
  • 实现Runnable接口。
  • ExecutorSenvice. Callable. Future 有返回值线程
  • 基于线程池的方式
  • 4种线程池
  • 如何停止一个正在运行的线程
  • notify0和notifyAll0有什么区别?
  • sleep0和wait0有什么区别?
  • volatile是什么?可以保证有序性吗?
  • Thread类中的start0和run0方法有什么区别?
  • 为什么wait, notify和nfifAllI这些方法不在thread类里面?
  • 为什么wait和ntify方法要在同步块中调用?
  • Java中interrupted和isInterruptedd方法的区别?
  • Java中synchronized和ReentrantLock有什么不同?
  • 有三个线程T1,T2,T3,如何保证顺序执行?
  • SynchronizedMap和ConcurrentHashMap有什么区别?
  • 什么是线程安全
  • Thread类中的yield方法有什么作用?
  • Java线程池中submit0和execute0方法有什么区别?
  • 说一说自己对于synchronized关键字的了解
  • 说说自己是怎么使用synchronized关键字,在项目中用到了吗ynchronized关键字最主要的三种使用方式?
  • 什么是线程安全? Vector是一 个线程安全类吗?
  • volatile关键字的作用?
  • 简述一下你对线程池的理解
  • 线程生命周期(状态)

​编辑

JVM面试题:

  • Serial垃圾收集器(单线程、复制算法)
  • ParNew垃圾收集器(Serial+ 多线程)
  • Parallel Scavenge收集器(多线程复制算法、高效)
  • Serial Old收集器(单线程标记整理算法)
  • Parallel Old收集器(多线程标记整理算法)
  • CMS收集器(多线程标记清除算法)
  • G1收集器
  • JVM类加载机制
  • 类加载器
  • 双亲委派
  • OSGI (动态模型系统)
  • 动态改变构造
  • 模块化编程与热插拔
  • JVM内存模型
  • 本地方法栈
  • 程序计数器
  • 方法区
  • 分代回收
  • 堆和栈的区别
  • 什么时候会触发FullGC
  • 什么是Java虚拟机?为什么Java被称作是“平台无关的编程语言”?
  • 对象分配规则
  • 描述一下JM加载class文件的原理机制?
  • Java对象创建过程

​编辑

Java中的IO与NIO面试题:

  • Java中10流?
  • Java 10与NIO的区别
  • 常用io类有哪些
  • 字节流与字符流的区别
  • 阻塞10模型
  • 非阻塞10模型
  • 多路复用10模型
  • 信号驱动10模型
  • 异步10模型
  • JAVA NIO
  • NIO的缓冲区
  • NIO的非阻塞
  • Channel
  • Buffer

​编辑

Mysql面试题:

  • 分库分表之后,d主键如何处理
  • 存储过程(特定功能的SQL语句集)
  • 存储过程优化思路
  • 触发器(一段能自动执行的程序)
  • 数据库并发策略
  • MySQL中有哪几种锁?
  • MySQL中有哪些不同的表格?
  • 简述在MySQL数据库中MyISAM和InnoDB的区别
  • MySQL中InnoDB支持的四种事务隔离级别名称,以及逐级之间的区别?
  • CHAR和VARCHAR的区别?
  • 主键和候选键有什么区别?
  • myisamchk是用来做什么的?
  • MyISAM Static 和MyISAM Dynamic有什么区别?
  • 如果一个表有一-列定义为TIMESTAMP,将发生什么?
  • 你怎么看到为表格定义的所有索引?
  • LIKE声明中的%和_是什么意思?
  • 列对比运算符是什么?
  • BLOB和TEXT有什么区别?
  • MySQL fetch. array 和MySQL fetch object 的区别是什么?
  • MyISAM表格将在哪里存储,并且还提供其存储格式?
  • MySQL如何优化DISTINCT?
  • 如何显示前50名?
  • 可以使用多少列创建索引?
  • NOW () 和CURRENT_ DATE () 有什么区别?
  • 什么是非标准字符串类型?
  • 什么是通用SQL函数?
  • MySQL支持事务吗?

​编辑

Redis面试题:

  • Redis是单进程单线程的?
  • 一个字符串类型的智能存储最大容量是多少?
  • Redis持久化机制
  • 缓存雪崩、缓存穿透、缓存预热、缓存更新、缓存降级等问题
  • 热点数据和冷数据是什么
  • 单线程的redis为什么这么快
  • redis的数据类型,以及每种数据类型的使用场景
  • redis的过期策略以及内存淘汰机制
  • Redis常见性能问题和解决方案?
  • 为什么Redis的操作是原子性的,怎么保证原子性的?
  • Redis事务
  • Redis的持久化机制是什么?各自的优缺点?
  • Redis常见性能问题和解决方案:
  • redis过期键的删除策略?
  • Redis的回收策略(海汰策略) ?
  • 为什么edis需要把所有数据放到内存中?
  • Redis的同步机制了解么?
  • Pipeline有什么好处,为什么要用pipeline?
  • 是否使用过Redis集群,集群的原理是什么?
  • Redis集群方案什么情况下会导致整个集群不可用?
  • Redis支持的Java客户端都有哪些?官方推荐用哪个?
  • Jedis与Redisson对比有什么优缺点?
  • Redis如何设置密码及验证密码?

​编辑

MongoDB面试题:

  • 当更新-个正在被迁移的块(Chunk). 上的文档时会发生什么?
  • MongoDB在A:(B,C}上建立索引,查询A:{B,C]和A:{C,B)都会使用索引吗?
  • 如果一个分片(Shard) 停止或很慢的时候,发起一个查询会怎样?
  • MongoDB支持存储过程吗?如果支持的话,怎么用?
  • 如何理解MongoDB中的GridFS机制,MongoDB为何使用GridFS来存储文件?
  • 什么是NoSQL数据库? NoSQL和RDBMS有什么区别?在哪些情况下使用和不使用NoSQL数据库?
  • MongoDB支持存储过程吗?如果支持的话,怎么用?
  • 如何理解MongoDB中的GridFS机制,MongoDB为何使用GridFS来存储文件?
  • 为什么MongoDB的数据文件很大?
  • 当更新-个正在被迁移的块(Chunk) 上的文档时会发生什么?
  • MongoDB在A:(B,C}上建立索引,查询A:{B,C]和A:{C,B)都会使用索引吗?
  • 如果一个分片(Shard) 停止或很慢的时候,发起一个查询会怎样
  • 分析器在MongoDB中的作用是什么?
  • 如果用户移除对象的属性,该属性是否从存储层中删除?
  • 能否使用日志特征进行安全备份?
  • 更新操作立刻fsync到磁盘?
  • 如何执行事务/加锁?
  • 什么是master或primary?
  • getLasterror的作用
  • 分片(sharding) 和复制(replication) 是怎样工作的?
  • 数据在什么时候才会扩展到多个分片(shard) 里?
  • 当我试图更新 一个正在被迁移的块(chunk) 上的文档时会发生什么?

​编辑

MyBatis 面试题:

  • 通常一个Xml映射文件,都会写一个Dao接口与之对应,请问,
  • 这个Dao接口的工作原理是什么? Dao接口里的方法,参数不同时,方法能重载吗?
  • 如何获取自动生成的(主)键值?
  • 在mapper 中如何传递多个参数?
  • Mybatis 动态sql有什么用?执行原理?有哪些动态sql?
  • Xml映射文件中,除了常见的selectlinsertlupdaeldelete标签之外,还有哪些标签?
  • Mybatis 的Xml映射文件中,不同的Xml映射文件,id 是否可以重复?
  • 为什么说Mybatis是半自动ORM映射工具?它与全自动的区别在哪里?
  • 一对一、一对多的关联查询?
  • MyBatis 实现一对一有几种方式?具体怎么操作的?
  • MyBatis 实现-对多有几种方式,怎么操作的?
  • Mybatis 是否支持延迟加载?如果支持,它的实现原理是什么?
  • Mybatis 的一级、二级缓存
  • 什么是MyBatis的接口绑定?有哪些实现方式?
  • 使用MyBatis的mapper接口调用时有哪些要求?
  • Mapper 编写有哪几种方式?
  • 简述Mybatis的插件运行原理,以及如何编写一个插件。
  • MyBatis实现一对一有几种方式?具体怎么操作的?

​编辑

Spring面试题:

  • Spring AOP and AspectU AOP有什么区别?
  • 如何理解Spring中的代理?
  • 什么是编织(Weaving) ?
  • Spring MVC框架有什么用?
  • 描述一下DispatcherServlet的工作流程
  • 介绍一下WebApplicationContext
  • 什么是spring?
  • 使用Spring框架的好处是什么?
  • Spring由哪些模块组成?
  • Spring的IOC和AOP机制
  • Spring中Autowired和Resource关键字的区别
  • 依赖注入的方式有几种,各是什么?
  • 讲一下什么是Spring
  • Spring MVC流程
  • springMVC是什么
  • SpringMVC怎么样设定重定向和转发的?
  • SpringMVC常用的注解有哪些
  • Spring的AOP理解
  • Spring的IOC理解
  • 解释一下spring bean的生命周期
  • 解释Spring支持的几种bean的作用域。
  • Spring基于xml注入bean的几种方式
  • Spring框架中都用到了哪些设计模式
  • 核心容器(应用上下文)模块
  • BeanFactory - BeanFactory实现举例。
  • XML BeanFactory
  • 解释AOP模块

​编辑

Spring Boot面试题:

  • 我们能否在spring-boot- starter-web中用jetty代替tomcat?
  • 如何使用Spring Boot生成一个WAR文件?
  • 如何使用Spring Boot部署到不同的服务器?
  • RequestMapping和GetMapping的不同之处在哪里?
  • 为什么我们不建议在实际的应用程序中使用Spring Data Rest?
  • 在Spring Initializer中,如何改变-个项目的包名字?
  • 可以配置application.propertierde的完整的属性列表在哪里可以找到?
  • JPA 和Hibernate有哪些区别?
  • 使用Spring Boot启动连接到内存数据库H2的JPA应用程序需!要哪些依赖项?
  • 如何不通过任何配置来选择Hibernate作为JPA的默认实现?
  • 指定的数据库连接信息在哪里?它是如何知道自动连接至H2的?
  • 我们如何连接一个像MSSQL或者orcale -样的外部数据库?
  • Spring Boot配置的默认H2数据库的名字是上面?为什么默认的数据库名字是testdb?
  • 如果H2不在类路径里面,会出现上面情况?
  • 你能否举一个以ReadOnly为事务管理的例子?
  • 发布Spring Boot用户应用程序自定义配置的最好方法是什么?
  • 配置文件的需求是什么?
  • 如何使用配置文件通过Spring Boot配置特定环境的配置?
  • 我们如何使用Maven设置Spring Boot应用程序?
  • 如何禁用特定的自动配置?
  • Spring boot支持哪些外部配置?
  • 如何对Spring Boot应用进行测试?
  • Spring Boot Actuator有什么用?
  • SpringBoot 中静态首页默认位置可以放在哪里?
  • SpringBoot中静态资源直接映射的优先级是怎样的?

​编辑

Spring Cloud面试题:

  • SpringBoot和SpringCloud的区别?
  • 什么是Hystrix断路器?我们需要它吗
  • 说说RPC的实现原理
  • 微服务的优点缺点?说下开发项目中遇到的坑?
  • spring cloud 和dubbo区别?
  • REST和RPC对比
  • 你所知道的微服务技术栈?
  • 微服务之间是如何独立通讯的?
  • springcloud如何实现服务的注册?
  • Eureka和Zookeeper区别
  • eureka自我保护机制是什么?
  • 什么是Ribbon?
  • 什么是feigin?它的优点是什么?
  • Ribbon和Feign的区别?
  • 什么是Spring Cloud Bus?
  • springcloud断路器作用?
  • Spring Cloud Gateway?
  • 作为服务注册中心,Eureka比Zookeeper好在哪里?
  • 什么是Ribbon负载均衡?
  • Ribbon负载均衡能干什么?
  • 什么是zuu|路由网关
  • 分布式配置中心能干嘛?

​编辑

数据结构面试题:

  • 栈(stack)
  • 队列(queue)
  • 链表(Link)
  • 散列表(Hash Table)
  • 排序二叉树
  • 前缨树
  • 红黑树
  • B-TREE
  • 位图

​编辑

算法面试题:

  • 数据里有{1,2,3,4,5,6,7,8,9}. 请随机打乱顺序,生成一个新的数组(请以代码实现)
  • 写出代码判断一个整数是不是2的阶次方(请代码实现,谢绝调用API方法)
  • 假设今日是2015年3月1日,星期日,请算出13个月及6天后是星期几,距离现在多少天(请用代码实现,谢绝调用API方法)
  • 有两个篮子,分别为A和B,篮子A里装有鸡蛋,篮子B里装有苹果,请用面向对象的思想实现两个篮子里的物品交换(请用代码实现)
  • 二分查找
  • 冒泡排序算法
  • 插入排序算法
  • 快速排序算法
  • 希尔排序算法
  • 归并排序算法
  • 桶排序算法
  • 基数排序算法
  • 剪枝算法
  • 回溯算法
  • 最短路径算法
  • 最小生成树算法
  • AES
  • RSA
  • CRC
  • MD5
  • 更多算法练习

​编辑

Kafka 面试题:

  • Consumer Group
  • 如何获取topic主题的列表
  • 生产者和消费者的命令行是什么?
  • consumer是推还是拉?
  • 讲讲kafka维护消费状态跟踪的方法
  • 讲一下主从同步
  • 为什么需要消息系统,mysql 不能满足需求吗?
  • Zookeeper对于Kafka的作用是什么?
  • Kafka判断一个节点是否还过着有那两个条件?
  • Kafka与传统MQ消息系统之间有三个关键区别
  • 讲一讲kafka的ack的三种机制|
  • 消费者如何不自动提交偏移量,由应用提交?
  • 消费者故障,出现过锁问题如何解决?
  • 如何控制消费的位置

​编辑

微服务 面试题:

  • Container在微服务中的用途是什么?
  • 什么是微服务架构中的DRY?
  • 什么是消费者驱动的合同(CDC) ?
  • Web, RESTful API在微服务中的作用是什么?
  • 您对微服务架构中的语义监控有何了解?
  • 我们如何进行跨功能测试?
  • 我们如何在测试中消除非决定论?
  • Mock或Stub有什么区别?
  • 您对Mike Cohn的测试金字塔了解多少?
  • Docker的目的是什么?
  • 什么是金丝雀释放?
  • 什么是持续集成(CI) ?
  • 什么是持续监测?
  • 架构师在微服务架构中的角色是什么?
  • 我们可以用微服务创建状态机吗?
  • 什么是微服务中的反应性扩展?

Elasticsearch 面试题

  • Elasticsearch 在部署时,对Linux的设置有哪些优化方法
  • ucence内部结构是什么?
  • Elasticsearch 是如何实现Master选举的?
  • Elasticsearch中的节点(比如共20个),其中的10个选
  • 个master, 另外10个选了另一个master, 怎么办?
  • 客户端在和集群连接时,如何选择特定的节点执行请求的?
  • 详细描述一下Elasticsearch索引文档的过程。
  • 详细描述一下Elasticsearch 更新和删除文档的过程。
  • 详细描述一 下Elasticsearch 搜索的过程
  • 在Elasticsearch中,是怎么根据一个词找到对应的倒排索
  • Elasticsearch在部署时,对Linux的设置有哪些优化方法?
  • 对于GC方面,在使用Elasticsearch时要注意什么?
  • Elasticsearch对于大数据量( 上亿量级)的聚合如何实现?
  • 在并发情况下,Elasticsearch 如何保证读写一致?
  • 如何监控Elasticsearch集群状态?
  • 介绍下你们电商搜索的整体技术架构
  • 介绍一下你们的个性化搜索方案?
  • 是否了解字典树?
  • 拼写纠错是如何实现的?

​编辑

Ps:由于篇幅限制,笔记无法全部为大家展示出来,就以截图主要内容的形式让大家参考啦
Logo

开放原子开发者工作坊旨在鼓励更多人参与开源活动,与志同道合的开发者们相互交流开发经验、分享开发心得、获取前沿技术趋势。工作坊有多种形式的开发者活动,如meetup、训练营等,主打技术交流,干货满满,真诚地邀请各位开发者共同参与!

更多推荐