转:class类相关知识

转:https://blog.csdn.net/javazejian/article/details/70768369

1.class类是按需加载,再jvm中class类是描述类的信息,不管创建多少个对象,只加载一次(堆中可以有多个对象),类的加载时机是运行时加载
2.使用字面常量的方式获取Class对象的引用不会触发类的初始化
3.类加载的过程:加载、验证、准备、解析、初始化
4.编译期静态常量不触发类的初始化,因为类已经创建完成了,触发的只是类的加载阶段 static final int xxx
(在编译阶段通过常量传播优化的方式将Initable类的常量staticFinal存储到了一个称为NotInitialization类的常量池中,
在以后对Initable类常量staticFinal的引用实际都转化为对NotInitialization类对自身常量池的引用,所以在编译期后,对编译期常量的引用都将在NotInitialization类的常量池获取,
这也就是引用编译期静态常量不会触发Initable类初始化的重要原因)
5.非编译期静态常量的引用会触发初始化,因为非编译期静态常量编译阶段是不确定的 static final Random(100)
6.引用静态常量会触发class类的初始化,因为静态常量在编译阶段是不确定的  static int xxx


7.关于类加载的初始化阶段,在虚拟机规范严格规定了有且只有5种场景必须对类进行初始化:

使用new关键字实例化对象时、读取或者设置一个类的静态字段(不包含编译期常量)以及调用静态方法的时候,必须触发类加载的初始化过程(类加载过程最终阶段)。

使用反射包(java.lang.reflect)的方法对类进行反射调用时,如果类还没有被初始化,则需先进行初始化,这点对反射很重要。

当初始化一个类的时候,如果其父类还没进行初始化则需先触发其父类的初始化。

当Java虚拟机启动时,用户需要指定一个要执行的主类(包含main方法的类),虚拟机会先初始化这个主类

当使用JDK 1.7 的动态语言支持时,如果一个java.lang.invoke.MethodHandle 实例最后解析结果为REF_getStatic、REF_putStatic、REF_invokeStatic的方法句柄,
并且这个方法句柄对应类没有初始化时,必须触发其初始化(这点看不懂就算了,这是1.7的新增的动态语言支持,其关键特征是它的类型检查的主体过程是在运行期而不是编译期进行的,
这是一个比较大点的话题,这里暂且打住)

8.泛化class对象引用==》
//编译无法通过
Class<Number> numberClass=Integer.class;
//通过
Class<?> intClass = int.class;
intClass = double.class;

//编译通过!
Class<? extends Number> clazz = Integer.class;
//赋予其他类型
clazz = double.class;
clazz = Number.class;

9.instanceof 关键字与isInstance方法===》instanceof是关键字,isInstance是class类的navicate方法;
instanceof是检测左边对象是不是右边类或者接口的实例化,被检测对象是null或者是基本类型返回未false
isInstance被测试的对象或者变量,如果obj是调用这个方法的class或接口的实例,则返回true。如果被检测的对象是null或者基本类型,那么返回值是false;
//判断这个对象是不是这种类型
obj.instanceof(class)
//判断这个对象能不能被转化为这个类
class.inInstance(obj)  父类是不能转换为子类的

class A {}

class B extends A {}
Testing x of type class reflex.A
x instanceof A true
x instanceof B false
A.isInstance(x) true
B.isInstance(x) false
x.getClass() == A.class true
x.getClass() == B.class false
x.getClass().equals(A.class)) true
x.getClass().equals(B.class)) false
Testing x of type class reflex.B
x instanceof A true
x instanceof B true
A.isInstance(x) true
B.isInstance(x) true
x.getClass() == A.class false
x.getClass() == B.class true
x.getClass().equals(A.class)) false
x.getClass().equals(B.class)) true

10.反射技术是在运行状态中任何一个类都能知道这个类的属性和方法,任何一个对象都能调用其中的属性和方法



 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值