java技巧:反射判斷field類型的操作
JAVA 反射機制中,Field的getModifiers()方法返回int類型值表示該字段的修飾符。
其中,該修飾符是java.lang.reflect.Modifier的靜態(tài)屬性。
對應表如下:
//判斷是不是private類型方法 public static boolean is Private(int modifiers){ retrurn ((modifiers & 0x2)!=0); }
分析一下,&是按位與操作符,0x2是十六進制,二進制是10,所以只有private類型按位與不為0.
補充:java反射獲取類的類名、屬性名、屬性類型、方法、執(zhí)行方法、構造函數
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); // 通過有參構造函數創(chuàng)建對象 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() begin System.out.println(field.getGenericType());//打印該類的所有屬性類型 // 如果類型是String if (field.getGenericType().toString().equals( "class java.lang.String")) { // 如果type是類類型,則前面包含"class ",后面跟類名 // 拿到該屬性的gettet方法 /** * 這里需要說明一下:他是根據拼湊的字符來找你寫的getter方法的 * 在Boolean值的時候是isXXX(默認使用ide生成getter的都是isXXX) * 如果出現NoSuchMethod異常 就說明它找不到那個gettet方法 需要做個規(guī)范 */ 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); } } // 如果類型是Integer if (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); } } // 如果類型是Double if (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); } } // 如果類型是Date if (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); } } // 如果類型是Short if (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); }
以上為個人經驗,希望能給大家一個參考,也希望大家多多支持腳本之家。
相關文章
SpringSecurity Jwt Token 自動刷新的實現
這篇文章主要介紹了SpringSecurity Jwt Token 自動刷新的實現,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧2020-06-06java中常見XML解析器的使用詳解(JAXP,DOM4J,Jsoup,JsoupXPath)
為了處理和操作XML數據,我們需要使用XML解析器,本文將介紹幾種常用的XML解析器,包括JAXP、DOM4J、Jsoup和JsoupXPath,需要的小伙伴可以參考一下2023-11-11Java?實現使用Comparable按照我們指定的規(guī)則排序
這篇文章主要介紹了Java?如何使用Comparable按照我們指定的規(guī)則排序,通過練習創(chuàng)建TreeSet集合使用無參構造方法,并按照年齡從小到大的順序排序,若年齡相同再按照姓名的字母順序排序展開內容,需要的朋友可以參考一下2022-04-04spring-gateway網關聚合swagger實現多個服務接口切換的示例代碼
這篇文章主要介紹了spring-gateway網關聚合swagger實現多個服務接口切換的示例代碼,本文給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下2022-03-03基于Map的computeIfAbsent的使用場景和使用方式
這篇文章主要介紹了基于Map的computeIfAbsent的使用場景和使用方式,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2021-09-09使用@Service注解出現No bean named 'xxxx'&
這篇文章主要介紹了使用@Service注解出現No bean named 'xxxx' available]錯誤的解決方案,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教2023-08-08