对Java的理解
- 平台无关性
- GC
- 语言特性
- 面向对象
- 类库
- 异常处理
平台无关性
为什么需要先编译成字节码再解析成机器码
字节码避免了每次都需要进行语法校验等准备工作;增加了平台的兼容性(其他语言转换成字节码也能在JVM上运行)。
JVM如何加载.class文件
JVM就是内存中的虚拟机。
反射
Java反射机制是指在运行状态中,对于任意一个类,都能够知道这个类的所有属性和方法;对于任意一个对象,都能够调用它的任意方法和属性;这种动态获取信息以及动态调用对象方法的功能称为Java语言的反射机制。
eg:
Class.forName创建类对象就是反射最简单的例子。
具体的代码在我的资源可看到,但是现在还在审核,需要的可以去下载(审核完记得的话会去把所需C币给取消了,没有的话可以提醒我一下)。
注:这里出现了很尴尬的问题,忘记使用getDeclaredConstructor().newInstance()去实例化对象了,Class.forName只是定义了一个类
类从编译到执行的过程
- 编译器将Robot.java 源文件译为Robot.class字节码文件;
- ClassLoader将字节码转换成JVM中的Class对象;
- JVM利用Class对象实例化Robot对象;
ClassLoader
作用
ClassLoader在Java中有着重要的作用,它主要工作在Class装载的加载阶段,其主要作用就是从系统外部获得Class二进制数据流。它是Java的核心组件,所有的Class都是由ClassLoader进行加载的,ClassLoader负责通过将Class文件里的二进制数据流装载近系统,然后交给Java虚拟机进行连接、初始化等操作。
ClassLoader的种类
- BootStrapClassLoader:C++编写,加载核心库java.*;
- ExtClassLoader:Java编写,加载扩展库javax.*;
- AppClassLoader:Java编写,加载程序所在目录;
- 自定义ClassLoader:Java编写,定制化加载
自定义的ClassLoader的关键函数:findClass函数重载,新建loadClassData函数
类加载器的双亲委派机制
作用:避免多份字节码重复加载。
类的加载方式
隐式加载:new;显式加载:class.forName、loadClass等
loadClass和Class.forName 的区别
(由上两图可知,ClassLoader的loadClass的resolve是false,而resolve代表的就是步骤二的链接)
主要区别就是loadClass只会执行第一步,而Class.forName则是完成了初始化的。
数据库连接就可以使用Class.forName
loadClass的实用例子:springIOC读取bean配置(lazyloading),因为这样不需要执行链接和初始化,从而加快加载工作,留到需要使用的时候再去链接和初始化。