java基础学习笔记之反射
反射 反射:将类的属性和方法映射成相应的类。 反射基本使用 获取Class类的三种方法:
根据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:
如果参与hascode计算的成员变量中途发生变化,则后面remove时失败,造成内存泄露 配置文件加载 类加载器加载只读配置文件 类名.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,写法有点讲究。
以前编译java代码时,有些conf/文件夹还要添加进依赖或者标记成source文件夹,里面明明都是xml文件,没Java源码。从这里,我现在知道了,是使用反射加载配置文件的缘故 内省(Instropector) & JavaBean JavaBean读取属性x的值的流程:变大写、补前缀、获取方法。 "x"-->"X"-->"getX"-->"MethodGetX" 简单实现: 使用java.beans.PropertyDescriptor类 麻烦实现: 使用java.beans.Introspector类,遍历getBeanInfo方法的返回值 JavaBean必须有一个不带参数的构造函数 使用BeanUtils工具包
(编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |