本文主要是介绍Java面试题夺命连环问,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!
如何实现一个ioc容器
- 配置文件配置包扫码路径
- 递归包扫描获取.class文件
- 反射·确定需要 交给IOC管理的类
- 对需要注入的类进行依赖注入
配置文件中指定需要扫描的包路径
- 定义一些注解,分别表示访问控制层,业务服务层,数据持久层,依赖注入注解,获取配置文件注解
- 从配置文件中获取需要扫描的包路径,获取到当前路径下的文件信息以及文件夹信息,我们将当前路径所有.class结尾的文件,添加一个Set集合进行储存
- 遍历set集合,获取在类上有指定注解的类,并将其交给ioc容器,定义一个安全的map用来储存这些对象
- 遍历这个ioc容器,获取到每一个类的实例,判断里面是否有依赖其他的类的实例,然后进行递归注入
java类加载器
- JDK自带有三种类加载器:bootStrap classLoader,ExtClassLoader,AppClassLoader
BootStrapClassLoader是ExtClassLoader的父类加载器,默认负责加载
%java_home%/lib/ext文件夹下的jar包和class类
继承ClassLoader实现自定义类加载器
JAVA中的异常体系
java中的所有异常都来自顶级父类Throwable
Throwable下有两个子类Exception和Error
Error是程序无法处理的错误,一旦出现这个错误,则程序将被停止运行
Exception不会导致程序停止,又分为两个部分RunTimeException运行异常和checkdException检查异常
RunTimeExption常常发生在程序运行过程中,会导致程序当前线程执行失败
CheckedException常常发生在程序编译过程中,会导致程序编译不通过
GC如何判断对象可以被回收
- 引用计数法:每个对象有一个引用技术属性,新增一个引用时计数器+1,引用释放时-1,计数器为0的时候可以回收
- 可信达分析法:从GC Roots 开始向下搜索,搜索所走过的路径称为引用链。当一个对象到GC Roots 没有任何引用链相链时,则证明此对象是不可用的,那么虚拟机就判断是可以回收对象
- 引用计数法,可能出行A 引用了B,B又引用了A,这个时候就算他们都不在使用了,但因为相互引用计数器=1,永远无法回收
GC Roots的对象有
- 虚拟机栈(栈针中的本地变量表)中引用的对象
- 方法区中类静态属性引用的对象
- 方法区中常量引用的对象
- 本地方法栈中JNI(即一般说的NAtive方法)引用对象
可达性算法中的不可达对象 并不是立即死亡的,对象拥有一次自我拯救的机会。对象被系统宣告死亡至少要经历两次标记过程:第一个是经过可达性分析发现没有与GC Roots相连接的引用链,第二次是在由虚拟机自动建立的Finalizer队列中判断是否需要执行finnalize方法
这篇关于Java面试题夺命连环问的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!