java 反射中的classload方式

题记:最近眼力脑力不够,今天犯了个错误,将o写成0,在反射时发现问题,还以为代码写错。

于是乎,有了这篇文字,把classload的方式,从新温习了一遍。

1、创建实例new

2、访问类或接口的静态变量,或对该静态变量赋值

3、调用类的静态方法

4、反射(class.forname())

5、初始化一个类的子类

6、jvm启动时被标明为启动类的类

除了以上6中方式,其他对类的使用都是被动使用,都不会导致类的初始化。

调用classloader类的loadclass方法加载一个类,并不是对类的主动使用,不会导致类的初始化。

接口的两重性:可以把接口当做类(因为在接口中有静态变量时,他可以被初始化);接口就是接口,和类无关(接口中 没有构造方法,所以不能被初始化)


Class.forName、实例对象.class(属性)、实例对象getClass()的区别

通过这几种方式,得到的都是Java.lang.Class对象

区别:

1、cl=A.class; JVM将使用类的类装载器将类A装入内存<前提是类还没有装入内存>,不对类A做类的初始化工作,返回类A的CLASS的对象

2、Class cc=o.getClass(),对象引用返回引用运行时真正所指的对象,因为儿子对象的引用可能会赋给父对象的引用变量中所属的类的class的对象 

3、class.forname("类名")人都知道装入类并做类的初始化


你可能感兴趣的:(java 反射中的classload方式)