Java面试大纲
01:项目介绍
此乃面试之时第一环节,主要考察你的概述能力和对业务的熟悉程度,
对需求的分析能力,沟通协作能力,产品思维能力,抽象建模能力等。
02:Java基础
1、List 和 Set 的区别
List和Set都是实现了collection接口的。
LIst:
可以允许重复对象。
可以插入多个null元素。
是一个有序的容器保证的每个元素的插入顺序,输出的顺序就是插入的顺序。
常用的实现类有ArrayList和LinkedList和Vector。
ArrayList和Vector底层是采用数组的方式存储数据,可以使用索引(数组的下标)来访问list中的元素,所以插入数据慢,查找可以根据下标查询,较快。Vector是线程安全的。LinkedList底层是双向链表实现存储,按照序号索引需要向前或者向后遍历,插入数据时只需要记录本项前后即可,插入和删除较快。
在多线程并发的时候ArrayList和LinkedList是非线程安全的,并且是不同步的,Vector所有的方法都用了synchronized方法,是线程安全的。
set:
不允许重复对象。
只允许一个null元素。
是一个无序容器,无法保证每个元素的插入顺序
常用的实现类有HashSet,LinkedHashSet和TreeSet。
2、HashSet 是如何保证不重复的
是靠元素重写hashcode()和equals()方法来保证。
添加元素时调用HashSet类中的add()方法,
public boolean add(E e){
return map.put(e,PRESENT)==null;
}
HashSet类中put()方法:
1:在for循环中首先遍历table中的元素
如果hash码值不相同,说明是一个新的元素,就保存。
如果hash码值相同,且equles判断相等,说明元素已经存在,不保存。
如果hash码值相同,且eques判断不相等,说明元素不存在,保存。
3、HashMap 是线程安全的吗,为什么不是线程安全的
HashMap是非线程安全的,多线程情况下不推荐使用HashMap,
4、HashMap 的扩容过程
5、HashMap 1.7 与 1.8 的 区别,说明 1.8 做了哪些优化,如何优化的
6、final finally finalize
final:Java中的关键字,修饰符。如果一个类被声明为final,那么就不能派生出新的子类。因此一个类不能同时被申请为final和abstract。
如果将变量和方法声明为final,那么他们在使用过程中就不会被改变
声明为final的变量必须在声明的时候给定初始值,在以后的引用中只能读取,不能修改。
不可改变的只是这个变量所保存的引用,并不是这个引用所指向的对象。
声明为fanl的方法,只能使用,不能重载。
finally:Java异常处理的补充,不管有没有异常发生finally块中的代码中会执行。
finalize:Java中的一个方法名,使用finalize()方法在垃圾收集器将对象从内存中清理出去的时候,做必要的清理工作。这个方法是在垃圾收集器确定这个对象没有被引用的时候对这个对象的调用,他是在Object类中定义的,因此所有的类都继承了他。
7、强引用 、软引用、 弱引用、虚引用
8、Java反射
在运行状态中,对于任何一个类都能知道这个类的所有属性和方法,
对于任何一个对象,都能够调用他的任意方法和属性,并且能改变他的属性。
9.多线程实现
java 中提供了三种创建线程的方法,
1,通过实现Runnable接口,创建一个实现Runnable接口的实现类,重写run()方法,可以在类中实例化线程对象。
2,通过继承Thread类,新建类继承Thread类,创建该类的实例,重写run()方法,调用start()方法执行。
3,通过Callable和Futere创建线程
01. 创建 Callable 接口的实现类,并实现 call() 方法,该 call() 方法将作为线程执行体,并且有返回值。
02. 创建 Callable 实现类的实例,使用 FutureTask 类来包装 Callable 对象,该 FutureTask 对象封装了该 Callable 对象的 call() 方法的返回值。
03. 使用 FutureTask 对象作为 Thread 对象的 target 创建并启动新线程。
04. 调用 FutureTask 对象的 get() 方法来获得子线程执行结束后的返回值。
03:Java并发
1、synchronized 的实现原理以及锁优化
Java中每一个对象都可以作为锁,这是实现synchronized同步的基础。
普通同步方法,锁是当前实例对象。
静态同步方法,锁是当前类的class对象。
同步方法块,锁是括号里面的对象。
当一个线程访问同步代码块时,它首先需要得到锁才能执行同步代码,当退出或者跑出异常时必须释放锁。
2、volatile 的实现原理
3、Java 的信号
4、synchronized 在静态方法和普通方法的区别
5、怎么实现所有线程在等待某个事件的发生才会去执行
6、CAS,CAS 有什么缺陷,如何解决
7、synchronized 和 lock 有什么区别
8、Hashtable 是怎么加锁的
9、HashMap 的并发问题
10、ConcurrenHashMap 介绍,1.8 中为什么要用红黑树
11、AQS
12、如何检测死锁,怎么预防死锁
13、Java 内存模型
14、如何保证多线程下 i++ 结果正确
15、线程池的种类,区别和使用场景
Java通过Executors提供四种线程池,分别为:
newCachedThreadPool创建一个可缓存线程池,如果线程池长度超过处理需要,可灵活回收空闲线程,若无可回收,则新建线程。
newFixedThreadPool 创建一个定长线程池,可控制线程最大并发数,超出的线程会在队列中等待。
newScheduledThreadPool 创建一个定长线程池,支持定时及周期性任务执行。
newSingleThreadExecutor 创建一个单线程化的线程池,它只会用唯一的工作线程来执行任务,保证所有任务按照指定顺序(FIFO, LIFO, 优先级)执行。
16、分析线程池的实现原理和线程的调度过程
17、线程池如何调优,最大数目如何确认
18、ThreadLocal原理,用的时候需要注意什么
04:Spring
1、BeanFactory 和 FactoryBean
BeanFactory是接口,提供了IOC容器的最基本形式,给具体的IOC容器的实现提供了规范。负责生产和管理bean的一个工厂,BeanFactory是IOC容器的核心接口,作用是:实例化,定位,配置应用程序中的对象及建立这些对象的依赖。他只是个接口,并不是IOC容器的具体实现。
FactoryBean是一个bean,不同于普通Bean的是:是一个能生产或者修饰对象生成的工厂Bean,它是实现了FactoryBean<T>接口的Bean,根据该Bean的ID从BeanFactory中获取的实际上是FactoryBean的getObject()返回的对象,而不是FactoryBean本身,如果要获取FactoryBean对象,请在id前面加一个&符号来获取。
2、Spring IOC 的理解,其初始化过程
3、BeanFactory 和 ApplicationContext
4、Spring Bean 的生命周期,如何被管理的
5、Spring Bean 的加载过程是怎样的
6、如果要你实现Spring AOP,请问怎么实现
7、如果要你实现Spring IOC,你会注意哪些问题
8、Spring 是如何管理事务的,事务管理机制
9、Spring 的不同事务传播行为有哪些,干什么用的
10、Spring 中用到了那些设计模式
04:数据库
数据库事物的四大特性:原子性,一致性,永久性,隔离性。
原子性:所有的数据库操作要么全部成功,要么全部失败回滚,
一致性:数据库操作必须是从一个一致性状态变换到另一个一致性状态,执行前和执行后都必须保持一致性。
永久性:一个事物如果被提交了,那么他对数据库的改变就是永久的,在系统遇到故障的时候也不会丢失事物的操作。
隔离性:多个用户访问数据库时,数据库为每一个用户开启的事物不能被其他事物所干扰,多个事物 并发之间要相互隔离。
05:分布式
1、Dubbo的底层实现原理和机制
2、描述一个服务从发布到被消费的详细过程
3、分布式系统怎么做服务治理
4、接口的幂等性的概念
5、消息中间件如何解决消息丢失问题
6、Dubbo的服务请求失败怎么处理
7、重连机制会不会造成错误
8、对分布式事务的理解
9、如何实现负载均衡,有哪些算法可以实现
10、Zookeeper的用途,选举的原理是什么
11、数据的垂直拆分水平拆分。
12、zookeeper原理和适用场景
13、zookeeper watch机制
14、redis/zk节点宕机如何处理
15、分布式集群下如何做到唯一序列号
16、如何做一个分布式锁
06:缓存
1、Redis用过哪些数据类型,以及Redis底层怎么实现
String(字符串) :key value的形式 ,是二进制安全的,可以包含任何数据。例如序列化的对象或者图片。赋值命令:set 取值命令:get
hash(哈希):
list(列表) :
set(无序不重复集合):
zset(有序不重复集合):
2、Redis缓存穿透,缓存雪崩
3、如何使用Redis来实现分布式锁
4、Redis的并发竞争问题如何解决
5、Redis持久化的几种方式,优缺点是什么,怎么实现的
6、Redis的缓存失效策略
7、Redis集群,高可用,原理
8、Redis缓存分片
9、Redis的数据淘汰策略
07:JVM
1、详细jvm内存模型
2、讲讲什么情况下回出现内存溢出,内存泄漏
3、说说Java线程栈
4、JVM 年轻代到年老代的晋升过程的判断条件是什么呢
5、JVM 出现 fullGC 很频繁,怎么去线上排查问题
6、类加载为什么要使用双亲委派模式,有没有什么场景是打破了这个模式
7、类的实例化顺序
父类静态成员和静态初始化块-------》子类静态成员和静态初始化块------》父类实例成员和实例初始化块-----》父类构造方法-------》子类实例成员和实例初始化块----------》子类构造方法
对象初始化的顺序:先静态方法在构造方法,先父类在子类。