反射
反射:將類的屬性和方法映射成相應的類。
反射基本使用
獲取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] }}輸出:
trueclass [Iclass [[Itrueclass java.lang.Object[[I@1540e19d][abc]
亂入: hashcode與內存泄露問題 參考java api:
如果參與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,寫法有點講究。
以前編譯java代碼時,有些conf/文件夾還要添加進依賴或者標記成source文件夾,里面明明都是xml文件,沒Java源碼。從這里,我現在知道了,是使用反射加載配置文件的緣故
內省(Instropector) & JavaBean
JavaBean讀取屬性x的值的流程:變大寫、補前綴、獲取方法。
"x"-->"X"-->"getX"-->"MethodGetX"
自己用內省操作
我目前沒用上,所以不貼代碼了,只附上核心類
簡單實現: 使用java.beans.PropertyDescriptor類
麻煩實現: 使用java.beans.Introspector類,遍歷getBeanInfo方法的返回值
JavaBean必須有一個不帶參數的構造函數
使用BeanUtils工具包
新聞熱點
疑難解答