专栏首页向治洪java基础之反射

java基础之反射

Contents

反射

反射:将类的属性和方法映射成相应的类。

反射基本使用

获取Class类的三种方法:

  • 类名.class
  • 对象名.getClass()
  • Class.forName("要加载的类名")

根据API写就行了,大致流程就是:

  • 用上述三种方式之一获取特定类的Class类,即该类对应的字节码
  • 调用Class对象的getConstructor(Class<?>... parameterTypes)获取构造方法对象
  • 调用是构造方法类ConstructornewInstance(Object... initargs)方法新建对象
  • 调用Class对象的getMethod(String name, Class<?>... parameterTypes)获取方法对象
  • 调用方法对象类Methodinvoke(Object obj, Object... args)方法,调用对象上相应方法

用方法的参数类型唯一标识一个方法,依据:方法的重载

数组的反射

下面这个例子主要说明几点:

  • 对于元素同类型的数组,同维数组,class一样
  • 不同维,class不同
  • 不同维的,父类都是Object,一样
  • 基本类型一维数组不能直接转换为Object[]
  • java.util.ArraysasList方法API看看
public class ReflectTest {
    public static void main(String[] args) {
        int [] a1 = new int[]{1,2,3};
        int [] a2 = new int[5];
        int [][] a3 = new int[2][3];
        System.out.println(a1.getClass() == a2.getClass());//true
        System.out.println(a1.getClass());//class [I
        System.out.println(a3.getClass());//class [[I
        System.out.println(a1.getClass().getSuperclass() == a3.getClass().getSuperclass());//true
        System.out.println(a2.getClass().getSuperclass());//class java.lang.Object

        //下句编译不通过:Error:(15, 42) java: 不可比较的类型: java.lang.Class<capture#1, 共 ? extends int[]>和java.lang.Class<capture#2, 共 ? extends int[][]>
        //System.out.println(a1.getClass() == a3.getClass());

        Object []b3 = a3;//通过
        //下句编译不通过   Error:(17, 24) java: 不兼容的类型: int[]无法转换为java.lang.Object[]
        //Object [] b1 = a1;

        String s1 = "abc";
        System.out.println(Arrays.asList(a1));//[[I@1540e19d]
        System.out.println(Arrays.asList(s1));//[abc]
    }
}

输出:

true
class [I
class [[I
true
class java.lang.Object
[[I@1540e19d]
[abc]

乱入: hashcode与内存泄露问题 参考java api:

  • hashcode一旦生成,不要变
  • 对象equals方法返回true,则hascode要一致
  • 反之,equals方法返回false,hascode不一定互异

如果参与hascode计算的成员变量中途发生变化,则后面remove时失败,造成内存泄露

配置文件加载

  • 类加载器加载只读配置文件

类名.class.getClassLoader().getResourceAsStream(str);

  • 类名.class.getResourceAsStream(str),实质还是调用类加载器。 源码截取(java.lang包下的Class.java):
 public InputStream getResourceAsStream(String name) {
    name = resolveName(name);
    ClassLoader cl = getClassLoader0();
    if (cl==null) {
        // A system class.
        return ClassLoader.getSystemResourceAsStream(name);
    }
    return cl.getResourceAsStream(name);
}

关于路径str,写法有点讲究。

  • 不加斜杠,相对路径: str = "config.properties";
  • 加斜杠,从classpath的根路径找: str = "/org/iot/ui/config.properties";

以前编译java代码时,有些conf/文件夹还要添加进依赖或者标记成source文件夹,里面明明都是xml文件,没Java源码。从这里,我现在知道了,是使用反射加载配置文件的缘故

内省(Instropector) & JavaBean

JavaBean读取属性x的值的流程:变大写、补前缀、获取方法。

"x"-->"X"-->"getX"-->"MethodGetX"
  • 自己用内省操作

我目前没用上,所以不贴代码了,只附上核心类

简单实现: 使用java.beans.PropertyDescriptor

麻烦实现: 使用java.beans.Introspector类,遍历getBeanInfo方法的返回值

JavaBean必须有一个不带参数的构造函数

  • 使用BeanUtils工具包
    • 字符串和整数转换(对比(PropertyUtils)
    • 属性级联操作
    • 操作map

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

我来说两句

0 条评论
登录 后参与评论

相关文章

  • 仿微信聊天表情发送

    如题,这是公司项目的一个功能模块,先上个效果图: ? 其次大致说说原理: 1,首先判断输入的字符,是否包含表情的文字,比如   ?  这个表情对应的文件名为 e...

    xiangzhihong
  • PullToRefreshScrollView 嵌套RecyclerView实现特卖列表倒计时抢购

    不久之前,我们谈到了通过Handler与timer及TimerTask结合实现倒计时抢购列表,那个是PullToRefreshListView实现的,今天要讲的...

    xiangzhihong
  • Android侧滑删除另一种实现,SwipeListView补充

    前不久在在做聊天删除功能的时候使用SwipeListView进行侧滑删除有一点小问题,因为SwipeListView嵌套在Fragment内的时候,会报一个转换...

    xiangzhihong
  • MySQL偏移量的一点分析

    在搭建MySQL主从的时候,change master是一个关键,如果没有使用GTID的方式,就需要使用偏移量和指定的binlog,每次需要手工去抓取这些信息,...

    jeanron100
  • 关于uint8_t、uint_least8_t、uiuint_fast8_t等说明

    版权声明:本文为博主原创文章,欢迎交流学习 ...

    大菊观
  • 1093 字符串A+B (20 分)

    版权声明:本文为博主原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。 ...

    韩旭051
  • [牛客]浙江大学计算机考研复试题目 - 欧拉回路

    欧拉回路是指不令笔离开纸面,可画过图中每条边仅一次,且可以回到起点的一条回路。现给定一个图,问是否存在欧拉回路?

    Kindear
  • 面对NASA获210亿美元加速重返月球,究竟是什么缩短太空竞争差距

    预算有多少?其公布的金额高达210.2亿美元。这是欧洲ESA的3倍多,是俄罗斯航天局的8倍,是中国航天局的10倍。毫无疑问,作为全球排名第一航天大国,其预算远超...

    用户7374987
  • 位运算的方法,小结

    文章来源未知----再次声明为转载... 本文是针对使用位运算来实现一些方法,我们都知道位运算的代价比其他符号运算都低,所以当一个方法只使用位运算且运算次数与其...

    Gxjun
  • P1341 无序字母对

    题目描述 给定n个各不相同的无序字母对(区分大小写,无序即字母对中的两个字母可以位置颠倒)。请构造一个有n+1个字母的字符串使得每个字母对都在这个字符串中出现。...

    attack

扫码关注云+社区

领取腾讯云代金券