走过春招,即是秋招,小编通过这么屡次的面试,这两天整顿了一份面试清单分享给大家,心愿能给大家一点帮忙(java 方向),感觉有帮忙的同学能够转发点个赞哦~~
01 JAVA 根底
1.1 java 知识点
- Hashmap 源码级把握,扩容,红黑树,最小树化容量,hash 抵触解决,有些面试官会提出发自灵魂的审讯,比方为什么是红黑树,别的树不能够吗;为什么 8 的时候树化,4 不能够吗,等等
- concureentHashMap,段锁,如何分段,和 hashmap 在 hash 上的区别,性能,等等
- HashTable,同步锁,这块可能会问你 synchronized 关键字 1.6 之后晋升了什么,怎么晋升的这些
- ArrayList 劣势,扩容,什么时候用
- LinkedList 劣势,什么时候用,和 arraylist 的区别 等等
- 根本类型和包装类型的区别,波及主动装箱和拆箱,怎么做的,原理
- String,StringBuffer,StringBuilder 哪个是平安的
- 字符串编码的区别,被问到过,我感觉比拟容易被忽视的一个点
- 什么是泛型,怎么用泛型
- static 能不能润饰 threadLocal,为什么,这道题我过后一听到其实挺懵逼的
- Comparable 和 Comparator 接口是干什么的,其区别
- 多态的原理是什么,感觉这个很容易被问到
- 接口和抽象类,面试官问我是怎么了解的,我说接口对应性能,抽象类对应属性,而后面试官给我说了他的认识,说抽象类更偏差于一种模板~ 而后又交换了一下各自的想法
- 如何通过反射和设置对象公有字段的值
- 疾速失败 (fail-fast) 和平安失败 (fail-safe) 的区别是什么
- synchronized 的实现原理以及锁优化?
- volatile 的实现原理?
- Java 的信号灯?
- synchronized 在静态方法和一般办法的区别?
- 怎么实现所有线程在期待某个事件的产生才会去执行?
- CAS?CAS 有什么缺点,如何解决?
- synchronized 和 lock 有什么区别?
- Hashtable 是怎么加锁的?
- List,Map,Set 接口在取元素师,各有什么特点
- 如何线程平安的实现一个计数器
- 生产者消费者模式,要求手写过代码,还是要晓得的
- 单例模式,饿汉式,懒汉式,线程平安的做法,两次判断 instance 是否为空,每次判断的作用是什么。
- 线程池,这个还是很重要的,在生产中用的挺多,四个线程池类型,其参数,参数的了解很重要,corepoolSize 怎么设置,maxpoolsize 怎么设置,keep-alive 各种的,和美团面试官探讨过阻塞队列在生产中的设置,他说他个别设置为 0,避免用户阻塞
- cyclicbarrier 和 countdownlatch 的区别,集体了解 赛马和点火箭
- 线程回调,这块 被问过让我设计一个 RPC,怎么实现,其实用到了回调这块的货色
- sleep 和 yeild 办法有什么区别
- volatile 关键字,可见性。
- 乐观锁和乐观锁的应用场景
- 乐观锁的常见实现形式:lock synchronized retreentlock
- 乐观锁:CAS MVCC
- 读写锁的实现形式,16 位 int 的前八位和后八位别离作为读锁和写锁的标记位
- 死锁的条件,怎么解除死锁,怎么观测死锁。
- 心愿大家可能好好看一下反射的原理,怎么确定类,怎么调办法
- RPC 框架,同步异步,响应工夫,这些都被问到过,还让设计过
-
同步,异步,阻塞,非阻塞 在深服气的面试中遇到过,最好再找一些利用场景加以了解
1.2 JVM
- 内存模型以及分区,须要具体到每个区放什么。
- 堆外面的分区:Eden,survival(from+ to),老年代,各自的特点。
- 对象创立办法,对象的内存调配,对象的拜访定位。
- GC 的两种断定办法
- GC 的三种收集办法:标记革除、标记整顿、复制算法的原理与特点,别离用在什么中央,如果让你优化收集办法,有什么思路?
- GC 收集器有哪些?CMS 收集器与 G1 收集器的特点
- Minor GC 与 Full GC 别离在什么时候产生?
- JVM 内存分哪几个区,每个区的作用是什么?
- 如和判断一个对象是否存活?(或者 GC 对象的断定办法)
- java 中垃圾收集的办法有哪些?
- 类加载器双亲委派模型机制?
- java 内存模型,java 类加载过程?
- 什么是类加载器,类加载器有哪些?
-
简述 java 内存调配与回收策率以及 Minor GC 和 Major GC
02 数据库
2.1 MySQL
- 事务四大个性(ACID)原子性、一致性、隔离性、持久性?
- 事务的并发?事务隔离级别,每个级别会引发什么问题,MySQL 默认是哪个级别?
- MySQL 常见的三种存储引擎(InnoDB、MyISAM、MEMORY)的区别?
- MySQL 的 MyISAM 与 InnoDB 两种存储引擎在,事务、锁级别,各自的实用场景?
- 查问语句不同元素(where、jion、limit、group by、having 等等)执行先后顺序
- 索引为什么要用 B + 树,B+ 树和 B - 树的区别是什么
- mysql 的默认事务级别,一共有哪些事务级别
- mysql 的一些语句,这些必定须要把握的
- mysql 锁,行锁,表锁,什么时候产生锁,怎么锁,原理
- 数据库优化,最左准则啊,程度分表,垂直分表
- 什么是长期表,长期表什么时候删除?
- MySQL B+Tree 索引和 Hash 索引的区别?
- sql 查问语句确定创立哪种类型的索引?如何优化查问?
- 汇集索引和非汇集索引区别?
- 有哪些锁(乐观锁乐观锁),select 时怎么加排它锁?
- 非关系型数据库和关系型数据库区别,劣势比拟?
- 数据库三范式,依据某个场景设计数据表?
- 数据库的读写拆散、主从复制,主从复制剖析的 7 个问题?
- 应用 explain 优化 sql 和索引?
- MySQL 慢查问怎么解决?
- 什么是 内连贯、外连贯、穿插连贯、笛卡尔积等?
- mysql 都有什么锁,死锁断定原理和具体场景,死锁怎么解决?
- varchar 和 char 的应用场景?
- mysql 高并发环境解决方案?
-
数据库解体时事务的复原机制(REDO 日志和 UNDO 日志)?
03 Spring 相干
spring 的两大个性 - ioc aop,实现原理
- 如果存在 A 依赖 B,B 依赖 A,那么是怎么加到 IOC 中去的
- beanFactory 的了解,怎么加载 bean
- FactoryBean 的了解
- 基于注解的模式,是怎么实现的,你晓得其原理吗,说一下
- 依赖抵触,有碰到过吗,你是怎么解决的~
- bean 的生命周期
- spring 中的主动拆卸形式
- BeanFactory 和 FactoryBean
- Spring IOC 的了解,其初始化过程?
- BeanFactory 和 ApplicationContext?
- Spring Bean 的生命周期,如何被治理的?Spring Bean 的加载过程是怎么的?
- 如果要你实现 Spring AOP,请问怎么实现?
- 如果要你实现 Spring IOC,你会留神哪些问题?
- Spring 是如何治理事务的,事务管理机制?
- Spring 的不同事务流传行为有哪些,干什么用的?
- Spring 中用到了那些设计模式?
- Spring MVC 的工作原理?
- Spring 循环注入的原理?
- Spring 如何保障 Controller 并发的平安?
- 你个别是怎么对 mvc 我的项目进行分层的
- dispatch-servlet 的工作原理
- 为什么有了 springmvc 还要在我的项目中应用 spring?
- springmvc 的运行机制,dispatch -》hanldermapping-—》handler -》handlerAdapter-》执行 handler-》modelandview -》返回 mv -》视图解析器 -》返回 view -》渲染响应
- 怎么避免依赖注入
- 怎么让 mapper 和 xml 对应
- 如何主动包装对象
- 和 spring 相比,做了什么扭转
- starter 你晓得哪些
- 如何部署 springmvc 我的项目 以及如何部署 springboot 我的项目
-
springboot 的插件,你应用过哪些
04 中间件
4.1 redis
- Redis 用过哪些数据数据,以及 Redis 底层怎么实现
- Redis 缓存穿透,缓存雪崩
- 如何应用 Redis 来实现分布式锁
- Redis 的并发竞争问题如何解决
- Redis 长久化的几种形式,优缺点是什么,怎么实现的
- Redis 的缓存生效策略
- Redis 集群,高可用,原理
- Redis 缓存分片,Redis 的数据淘汰策略
- 为什么抉择 redis,有什么益处,基于内存,抗压
- redis 集群怎么进行数据调配,hash 槽
- redis 的主从复制是怎么实现的
- redis 的数据结构 最常问 hash 是什么,sorted set 怎么实现的
- 因为我的项目的起因,问我 redis 是怎么保障高可用的,主从和集群怎么加在一起
- redis 和 memcache 的区别
- redis 分布式锁的实现原理 setNX 啥的
- redis 模仿 session,除了 redis 你还思考过别的吗
- redis 的缓存击穿,怎么解决这个问题
- redis 是基于内存的,那么它有长久化吗,aof rdb
-
aof 和 rdb 的优缺点,你在我的项目中应用的哪一个
4.2 MQ
- 为什么抉择 rabbitMQ,社区沉闷,高并发
- 别的 MQ 也要理解,比方 RocketMQ(阿里的,java 开发,再次开发,并发高,分布式,出错少)
- ActiveMQ,kafka
- topic 和 block
- MQ 的作用,同步转异步,打消峰值
- 如何保证数据一致性,即原子性,ack
-
音讯队列在我的项目中的利用
4.3 nginx
- 怎么配置负载平衡
- 怎么限流
- 怎么应用 nginx 缓存
- 为什么应用 nginx,有别的替代品吗
- 请解释 x Nginx 如何解决 P HTTP 申请
- 在 x Nginx 中,如何应用未定义的服务器名称来阻止解决申请? ?
- 应用“反向代理服务器”的长处是什么?
- x Nginx 服务器上的 r Master 和 和 r Worker 过程别离是什么?
- nginx 的压力测试,你测试过吗,能抗住多少压力
- 你如何通过不同于 0 80 的端口开启 Nginx?
- 是否有可能将 x Nginx 的谬误替换为 2 502 谬误、503
-
s stub_status 和 和 r sub_filter 指令的作用是什么? ?
4.5 dubbo
- 原理,怎么用
- 和 erueka 有什么区别
- 为什么要用 dubbo,不必行不行?
- 跨域申请的一些知识点
- Dubbo 反对哪些协定,每种协定的利用场景,优缺点?
- Dubbo 超时工夫怎么设置?
- Dubbo 集群的负载平衡有哪些策略
- Dubbo 的次要利用场景?
- Dubbo 服务注册与发现的流程?
- Dubbo 中 中 zookeeper 做注册核心,如果注册核心集群都挂掉,发布者和订阅者之间还能通信么?
-
dubbo 服务负载平衡策略?
05 其余插件
5.1 shiro
- 怎么做权限管制
- 为什么应用 shiro,你间接应用 aop 不也是一样的吗,shiro 还有标签~ 各种扯
- shiro 的两个最重要的函数
-
认证和受权是怎么做的
5.2 docker
- 和 vmware 的区别
- 你个别是怎么部署的 IDEA,间接把我的项目部署到 docker 并打包到云服务器
-
docker 的益处,小,快
06 Linux
- 常见的命令
- sed 和 awk 感觉 linux 必考。。
- linux 的应用场景,你什么时候会用 linux —》安排服务器
- 怎么查看过程和杀死过程
- 打印一个文件夹中的所有文件
- float 在计算机中是怎么存储的,过后被问到的时候,我也在问本人,怎么存的~~~ 佛了
- 线程和过程的区别
- 线程的通信形式,过程的通信形式
- 零碎线程的数量下限是多少
- 页式存储的概念
-
内存碎片,你有理解过吗,有想过解决方案吗~
07 算法
7.1 排序算法
- 八大排序算法真的是面试宠儿
- 最常考 疾速排序 和归并排序
- 哪些排序算法是稳固的 哪些是不稳固的
-
堆排 也应该把握
7.2 树
- 依据遍历后果复原树,递归
- 二叉搜寻树第 k 大
- 树的和为 k 的门路
- 档次遍历
- 依据档次遍历和后序遍历复原树
- 镜像树
- 树的深度
-
是不是均衡二叉树
7.3 链表
- 反转链表
- 链表环的入口
- 穿插链表的交点
- 简单链表的复制
-
二叉搜寻树变成双向链表
7.4 回溯算法
- 走迷宫
-
游戏通关
7.5 递推算法
- 走台阶
-
断钢筋
7.6 背包问题
-
装最多的货色
7.7 贪婪算法
- 笼罩问题
-
工夫问题
08 设计模式
- 面试中设计模式其实也是挺重要的
- Java 中什么叫单例设计模式?请用 Java 写出线程平安的单例模式
- 在 Java 中,什么叫观察者设计模式(observer design pattern)
- 应用工厂模式最次要的益处是什么?在哪里应用
- 举一个用 Java 实现的装璜模式(decorator design pattern)?它是作用于对象档次还是类档次?
- 在 Java 中,什么时候用重载,什么时候用重写?
- 举例说明什么状况下会更偏向于应用抽象类而不是接口
- 观察者模式
- 适配模式
-
工厂模式
…总结
记住,面试最重要的事就是:刷题刷题刷题刷题,天天作死的刷~
以上就是我在回忆面试过程所能想到的一些问题,可能不够全面,供大家参考参考,并且下面我列出的这些题目都已整顿出答案,全部都是 PDF 文档
—— 答案传送