今天在研究代码时候,发现一个Class类的方法cast() 看了一下源码。写出来分享一下。
先定义一个接口 Tree
//抽象出 一个父类 即使 没有这个也没事 可以返回object 这个万类之父
public interface Tree {
//输出自己的品种
void sout();
//空对象模式 需要的
boolean isNUll();
}
再创建两个实现类 Apple 和Banana
//具体的类
public class AppleTree implements Tree {
@Override
public void sout() {
System.out.println("我是苹果树");
}
@Override
public boolean isNUll() {
return false;
}
}
//具体的类
public class BananaTree implements Tree {
@Override
public void sout() {
System.out.println("我是香蕉树");
}
@Override
public boolean isNUll() {
return false;
}
}
这里有读者会说了,你这个上面的注释 是什么鬼。 其实 你只要翻我博客的话 就会发现,我写工厂模式和空对象模式 都用到了这个。
至于,现在 为什么还是这个? 因为 我懒。
重点部分
package com.zfh.test.factory;
public class CastMain {
public static void main(String[] args) {
AppleTree appleTree = new AppleTree();
Tree one = Tree.class.cast(appleTree);
one.sout();
//强制类型转换
Tree force = (Tree) appleTree;
force.sout();
Tree two = BananaTree.class.cast(appleTree);
two.sout();
}
}
运行这部分代码,结果如下、
调用了两次 apple类的方法,到 Tree two = BananaTree.class.cast(appleTree);
抛异常了。异常告诉我们 Banana 不能转换成 Apple。
到这里 有的人就明白了 Tree one = Tree.class.cast(appleTree);
不就是强制转换么? 我可以肯定的告诉你 。嗯 是的 就是强制转换类型
看源码
@HotSpotIntrinsicCandidate
public T cast(Object obj) {
if (obj != null && !isInstance(obj))
throw new ClassCastException(cannotCastMsg(obj));
return (T) obj;
}
源码里面 将得到的obj 用T泛型 强制转换了,至于T泛型 在哪里定义的public final class Class<T> implements java.io.Serializable, GenericDeclaration, Type, AnnotatedElement
也就是说呢 Tree.class 和Class< Tree> 两者是等价
总结
Class.cast(Object obj)方法 就是作用就是强制类型转换。将obj转化成T类型。