太悲伤了,女朋友面试惨遭面试官吊打,半夜偷偷摸摸躲在被子里抹眼泪刷题
五、Spring 架构
==========
- Spring Boot、Spring MVC 和 Spring 有什么区别? 
- BeanFactory 和 ApplicationContext 有什么区别? 
- 什么是基于 Java 的 Spring 注解配置? 给一些注解的例子. 
- 请解释 Spring Bean 的生命周期? 
- Spring 框架中的单例 Beans 是线程安全的么? 
- SpringMvc 的控制器是不是单例模式,如果是,有什么问题,怎么解决? 
- SpringMVC 怎么样设定重定向和转发的? 
- 当一个方法向 AJAX 返回特殊对象,比如 Object,List 等,需要做什么处理? 
- SpringMvc 用什么对象从后台向前台传递数据的? 
- 服务注册和发现是什么意思?Spring Cloud 如何实现? 
- 使用 Spring Cloud 有什么优势? 
- 什么是 Hystrix 断路器?我们需要它吗? 
- 什么是 Spring Cloud Bus?我们需要它吗? 
- 如何实现 Spring Boot 应用程序的安全性? 
- Spring Boot 配置的默认 H2 数据库的名字是上面?为什么默认的数据库名字是 testdb? 
六、线程问题
======
- stop() 和 suspend() 方法为何不推荐使用? 
- 同步和异步有何异同,在什么情况下分别使用它们? 
- 线程间通信,wait 和 notify 
- 什么是线程饿死,什么是活锁? 
- atomicinteger 和 volatile 等线程安全操作的关键字的理解和使用 
- volatile 变量是什么?volatile 变量和 atomic 变量有什么不同? 
- 当一个线程进入一个对象的一个 synchronized 方法后,其它线程是否可进入此对象的其它方法? 
- 简述 synchronized 和 java.util.concurrent.locks.Lock 的异同? 
- 多线程之间通信的同步问题,synchronized 锁的是对象,衍伸出和 synchronized 相关很多的具体问题,例如同一个类不同方法都有 synchronized 锁,一个对象是否可以同时访问。或者一个类的 static 构造方法加上 synchronized 之后的锁的影响。 
- volatile 类型变量提供什么保证?能使得一个非原子操作变成原子操作吗? 
- 了解可重入锁的含义,以及 ReentrantLock 和 synchronized 的区别 
- Java 创建线程之后,直接调用 start()方法和 run()的区别 
- 同步的数据结构,例如 concurrentHashMap 的源码理解以及内部实现原理,为什么它是同步的且效率高 
- 常用的线程池模式以及不同线程池的使用场景 
- newFixedThreadPool 此种线程池如果线程数达到最大值后会怎么办,底层原理。 
七、网络方面
======
- 为什么要三次握手 
- 二次握手有什么问题 
- 三次握手有哪些缺陷 
- TCP 是如何控制流量的 
- 发送方发送频率过高造成丢包,TCP 是如何解决的 
- HTTPs 为什么要用对称加密+非对称加密,相对于只使用非对称加密有什么好处 
- 讲一下 OSI 网络架构 
- HTTP 在哪一层 
- HTTP 报文结构 
- HTTP 首部字段 
- HTTPs 加密在哪一层实现 
- http 是无状态通信,http 的请求方式有哪些,可以自己定义新的请求方式么。 
- socket 通信,以及长连接,分包,连接异常断开的处理。 
- socket 通信模型的使用,AIO 和 NIO。 
- socket 框架 netty 的使用,以及 NIO 的实现原理,为什么是异步非阻塞 
八、MySQL 数据库
==========
- 务四大特性(ACID)原子性、一致性、隔离性、持久性? 
- 查询语句不同元素(where、jion、limit、group by、having 等等)执行先后顺序? 
- MySQL 常见的三种存储引擎(InnoDB、MyISAM、MEMORY)的区别? 
- MySQL 的 MyISAM 与 InnoDB 两种存储引擎在,事务、锁级别,各自的适用场景? 
- mysql 高并发环境解决方案? 
- 事务的并发?事务隔离级别,每个级别会引发什么问题,MySQL 默认是哪个级别? 
- MySQL B+Tree 索引和 Hash 索引的区别? 
- 有哪些锁(乐观锁悲观锁),select 时怎么加排它锁? 
- sql 查询语句确定创建哪种类型的索引?如何优化查询? 
- 聚集索引和非聚集索引区别? 
- mysql 都有什么锁,死锁判定原理和具体场景,死锁怎么解决? 
- 非关系型数据库和关系型数据库区别,优势比较? 
- MySQL 慢查询怎么解决? 
- 数据库的读写分离、主从复制,主从复制分析的 7 个问题? 
- 数据库崩溃时事务的恢复机制(REDO 日志和 UNDO 日志)? 
九、Redis 缓存
=========
- redis 事务相关命令有哪些? 
- 为什么要用 redis /为什么要用缓存(高性能、高并发) 
- 为什么要用 redis 而不用 map/guava 做缓存? 
- redis 和 memcached 的区别 
- 请介绍一下 Redis 的数据类型 SortedSet(zset)以及底层实现机制? 
- redis 常见数据结构以及使用场景分析(String、Hash、List、Set、Sorted Set) 
- redis 设置过期时间 
- redis 内存淘汰机制(MySQL 里有 2000w 数据,Redis 中只存 20w 的数据,如何保证 Redis 中的数据都是热点数据?) 
redis 持久化机制(怎么保证 redis 挂掉之后再重启数据可以进行恢复)
- redis 事务 
- Redis 常见异常及解决方案(缓存穿透、缓存雪崩、缓存预热、缓存降级) 
- 分布式环境下常见的应用场景(分布式锁、分布式自增 ID) 
- Redis 集群模式(主从模式、哨兵模式、Cluster 集群模式) 
- 如何解决 Redis 的并发竞争 Key 问题 
- 如何保证缓存与数据库双写时的数据一致性? 
十、JVM 相关
=======
- 如何判断一个对象是否存活?(或者 GC 对象的判定方法) 
- java 中垃圾收集的方法有哪些? 
- 简述 java 垃圾回收机制? 
- GC 的两种判定方法? 
- Minor GC 与 Full GC 分别在什么时候发生? 
- JVM 内存分哪几个区,每个区的作用是什么? 
- GC 收集器有哪些?CMS 收集器与 G1 收集器的特点 
- GC 的三种收集方法:标记清除、标记整理、复制算法的原理与特点,分别用在什么地方,如果让你优化收集方法,有什么思路? 
- 类加载器双亲委派模型机制? 
- java 类加载过程? 
- 简述 java 类加载机制? 
- 什么是类加载器,类加载器有哪些? 
- 简述 java 内存分配与回收策略以及 Minor GC 和 Major GC 
- HotSpot 虚拟机对象探秘 
- HotSpot 垃圾收集器 
十一、调优方面
=======
- 垃圾回收器的基本原理是什么?垃圾回收器可以马上回收内存吗?有什么办法主动通知虚拟机进行垃圾回收? 
- Java 中会存在内存泄漏吗,请简单描述。 
- 如果对象的引用被置为 null,垃圾收集器是否会立即释放对象占用的内存? 
- finalize() 方法什么时候被调用?析构函数 (finalization) 的目的是什么? 
- 串行(serial)收集器和吞吐量(throughput)收集器的区别是什么? 
- 什么是分布式垃圾回收(DGC)?它是如何工作的? 
- 你怎样给 tomcat 去调优? 
- Tomcat 的优化经验 
- 在 Java 中,对象什么时候可以被垃圾回收? 
- System.gc() 和 Runtime.gc() 会做什么事情? 
- Java 中会存在内存泄漏吗,请简单描述 
- GC 是什么? 为什么要有 GC? 
- JVM 的永久代中会发生垃圾回收么? 
- tomcat 有哪几种 Connector 运行模式(优化)? 
- 内存调优 
十二、设计模式
=======
- 21 种设计模式知识要点 
- 请列举出在 JDK 中几个常用的设计模式? 
- 什么是设计模式?你是否在你的代码里面使用过任何设计模式? 
- 在 Java 中,什么叫观察者设计模式(observer design pattern)? 
- 使用工厂模式最主要的好处是什么?在哪里使用? 
- 在 Java 中,什么时候用重载,什么时候用重写? 
- 在 Java 中,为什么不允许从静态方法中访问非静态变量? 
- 设计一个 ATM 机,请说出你的设计思路? 
- 举一个用 Java 实现的装饰模式(decorator design pattern)?它是作用于对象层次还是类层次 
- 举例说明什么情况下会更倾向于使用抽象类而不是接口? 
十三、算法 &数据结构
==========
- 如何仅用递归函数和栈操作逆序一个栈? 
- 将单向链表按某值划分成左边小、中间相等、右边大的形式 
- 分别用递归和非递归方式实现二叉树先序、中序和后序遍历 
- 斐波拉契系列问题的递归和动态规划 
- 判断字符数组中是否有的字符都只出现过一次 
- 在有序但含有空的数组中查找字符串 
- 只用 2GB 内存在 20 亿个整数中找到出现次数最多的数 
- 未排序数组中累加和小于或等于给定值的最长子数组长度 
- 从 5 随机到 7 随机及其扩展 
- 最大值减去最小值小于或等于 num 的子数组数量 
- 环形单链表的约瑟夫问题 
- 将单链表的每 K 个节点之间逆序 
- 在二叉树中找到累加和为指定值的最长路径长度 
- 判断一棵二叉树是否为搜索二叉树和完全二叉树 
- 最长公共子序列问题 
十四、并发
=====
- 什么是可重入性 , 为什么说 Synchronized 是可重入锁? 
- 为什么说 Synchronized 是一个悲观锁?乐观锁的实现原理又是什么?什么是 CAS,它有 什么特性? 
- 乐观锁一定就是好的吗? 
- JVM 对 Java 的原生锁做了哪些优化? 
- ReentrantLock 是如何实现可重入性的? 
- 跟 Synchronized 相 比 ,可重入锁 ReentrantLock 其实现原理有什么不同? 
- 如何让 Java 的线程彼此同步?你了解过哪些同步器?请分别介绍下 。 
- CyclicBarrier 和 CountDownLatch 看起来很相似,请对比下呢? 
- 线程池中的线程是怎么创建的?是一开始就随着线程池的启动创建好的吗? 
- 既然提到可以通过配置不同参数创建出不同的线程池,那么 Java 中默认实现好的线程池又 有哪些呢?请比较它们的异同 
- 请谈谈 volatile 有什么特点,为什么它能保证变量对所有线程的可见性? 
- 什么是 Java 的内存模型,Java 中各个线程是怎么彼此看到对方的变量的? 
- 既然 volatile 能够保证线程间的变量可见性,是不是就意味着基于 volatile 变量的运算就是并 发安全的 ? 
- 很多人都说要慎用 ThreadLocal,谈谈你的理解,使用 ThreadLocal 需要注意些什么? 
- 请谈谈 AQS 框架是怎么回事儿? 
十五、操作系统/Linux
=============
- 死锁产生的原因 
- 进程、线程区别,什么时候用线程 
- 如何实现一个线程池,Java 中线程池如何进行配置 
- linux 中有哪些常见的指令,进行介绍 
- select、poll、epoll 有没有了解过,讲解一下 
- 线程切换,引申到 Java 阻塞??运行 
- 如何分层复制/home 目录到另一个目录? 
- 什么是安装 Linux 所需的最小分区数量,以及如何查看系统启动信息? 
- 如何暂停一个正在运行的进程,把其放在后台(不运行)? 
- 什么是页面错误,它是怎么发生的? 
全部答案解析如下:(不一一截图了,全在下面这一块,已经全部整理成这些 PDF 了)
需要获取得话麻烦一键三连之后看下图小助理的微信:(13210158912)添加即可免费获取到哦











 
    
评论