java技巧:反射判斷field類型的操作
JAVA 反射機制中,Field的getModifiers()方法返回int類型值表示該字段的修飾符。
其中,該修飾符是java.lang.reflect.Modifier的靜態屬性。
對應表如下://判斷是不是private類型方法public static boolean is Private(int modifiers){ retrurn ((modifiers & 0x2)!=0);}
分析一下,&是按位與操作符,0x2是十六進制,二進制是10,所以只有private類型按位與不為0.
補充:java反射獲取類的類名、屬性名、屬性類型、方法、執行方法、構造函數
public class Demo02 { @SuppressWarnings('all') public static void main(String[] args) throws Exception {// 另一個com.sg.myReflection.bean包下的User類String path = 'com.sg.myReflection.bean.User';try { Class clazz = Class.forName(path); // 獲取類名 String strName01 = clazz.getName();// 獲取完整類名com.sg.myReflection.bean.User String strName02 = clazz.getSimpleName();// 直接獲取類名 User // 獲取屬性 Field[] field01 = clazz.getFields(); // 返回屬性為public的字段 Field[] field02 = clazz.getDeclaredFields(); // 返回所有的屬性 Field field03 = clazz.getDeclaredField('id'); // 獲取屬性為id的字段 // 獲取普通方法 Method[] Method01 = clazz.getDeclaredMethods(); // 返回public方法 Method method = clazz.getDeclaredMethod('getId', null); // 返回getId這個方法,如果沒有參數,就默認為null // 獲取構造方法 User u1 = (User) clazz.newInstance(); // 獲取無參的構造函數這里的前提的保證類中應該有無參的構造函數 // 獲取參數為(int,String,int)的構造函數 Constructor c2 = clazz.getDeclaredConstructor(int.class, String.class, int.class); // 通過有參構造函數創建對象 User u2 = (User) c2.newInstance(1001, '小小', 18); // 通過反射調用普通方法 User u3 = (User) clazz.newInstance(); Method method03 = clazz.getDeclaredMethod('setId', int.class); method.invoke(u3, 1002); // 把對象u3的id設置為1002 // 通過反射操作普通的屬性 User u4 = (User) clazz.newInstance(); Field f = clazz.getDeclaredField('name'); f.setAccessible(true); // 設置屬性可以直接的進行訪問 f.set(u4, '石頭');} catch (ClassNotFoundException e) { e.printStackTrace();} }}
public static void getObjectValue(Object object) throws Exception {//我們項目的所有實體類都繼承BaseDomain (所有實體基類:該類只是串行化一下)//不需要的自己去掉即可if (object != null && object instanceof BaseDomain) {//if (object!=null ) ----begin // 拿到該類 Class<?> clz = object.getClass(); // 獲取實體類的所有屬性,返回Field數組 Field[] fields = clz.getDeclaredFields(); for (Field field : fields) {// --for() beginSystem.out.println(field.getGenericType());//打印該類的所有屬性類型// 如果類型是Stringif (field.getGenericType().toString().equals('class java.lang.String')) { // 如果type是類類型,則前面包含'class ',后面跟類名 // 拿到該屬性的gettet方法 /** * 這里需要說明一下:他是根據拼湊的字符來找你寫的getter方法的 * 在Boolean值的時候是isXXX(默認使用ide生成getter的都是isXXX) * 如果出現NoSuchMethod異常 就說明它找不到那個gettet方法 需要做個規范 */ Method m = (Method) object.getClass().getMethod( 'get' + getMethodName(field.getName())); String val = (String) m.invoke(object);// 調用getter方法獲取屬性值 if (val != null) {System.out.println('String type:' + val); }}// 如果類型是Integerif (field.getGenericType().toString().equals('class java.lang.Integer')) { Method m = (Method) object.getClass().getMethod( 'get' + getMethodName(field.getName())); Integer val = (Integer) m.invoke(object); if (val != null) {System.out.println('Integer type:' + val); }}// 如果類型是Doubleif (field.getGenericType().toString().equals('class java.lang.Double')) { Method m = (Method) object.getClass().getMethod( 'get' + getMethodName(field.getName())); Double val = (Double) m.invoke(object); if (val != null) {System.out.println('Double type:' + val); }}// 如果類型是Boolean 是封裝類if (field.getGenericType().toString().equals('class java.lang.Boolean')) { Method m = (Method) object.getClass().getMethod( field.getName()); Boolean val = (Boolean) m.invoke(object); if (val != null) {System.out.println('Boolean type:' + val); }}// 如果類型是boolean 基本數據類型不一樣 這里有點說名如果定義名是 isXXX的 那就全都是isXXX的// 反射找不到getter的具體名if (field.getGenericType().toString().equals('boolean')) { Method m = (Method) object.getClass().getMethod( field.getName()); Boolean val = (Boolean) m.invoke(object); if (val != null) {System.out.println('boolean type:' + val); }}// 如果類型是Dateif (field.getGenericType().toString().equals('class java.util.Date')) { Method m = (Method) object.getClass().getMethod( 'get' + getMethodName(field.getName())); Date val = (Date) m.invoke(object); if (val != null) {System.out.println('Date type:' + val); }}// 如果類型是Shortif (field.getGenericType().toString().equals('class java.lang.Short')) { Method m = (Method) object.getClass().getMethod( 'get' + getMethodName(field.getName())); Short val = (Short) m.invoke(object); if (val != null) {System.out.println('Short type:' + val); }}// 如果還需要其他的類型請自己做擴展 }//for() --end}//if (object!=null ) ----end } // 把一個字符串的第一個字母大寫、效率是最高的、 private static String getMethodName(String fildeName) throws Exception{byte[] items = fildeName.getBytes();items[0] = (byte) ((char) items[0] - ’a’ + ’A’);return new String(items); }
以上為個人經驗,希望能給大家一個參考,也希望大家多多支持好吧啦網。
相關文章: