欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

java技巧:反射判斷field類型的操作

 更新時間:2021年05月20日 08:38:41   作者:小虎周  
這篇文章主要介紹了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 自動刷新的實現

    這篇文章主要介紹了SpringSecurity Jwt Token 自動刷新的實現,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2020-06-06
  • java中常見XML解析器的使用詳解(JAXP,DOM4J,Jsoup,JsoupXPath)

    java中常見XML解析器的使用詳解(JAXP,DOM4J,Jsoup,JsoupXPath)

    為了處理和操作XML數據,我們需要使用XML解析器,本文將介紹幾種常用的XML解析器,包括JAXP、DOM4J、Jsoup和JsoupXPath,需要的小伙伴可以參考一下
    2023-11-11
  • Java?實現使用Comparable按照我們指定的規(guī)則排序

    Java?實現使用Comparable按照我們指定的規(guī)則排序

    這篇文章主要介紹了Java?如何使用Comparable按照我們指定的規(guī)則排序,通過練習創(chuàng)建TreeSet集合使用無參構造方法,并按照年齡從小到大的順序排序,若年齡相同再按照姓名的字母順序排序展開內容,需要的朋友可以參考一下
    2022-04-04
  • SpringBoot接口參數的默認值與必要性最佳實踐記錄

    SpringBoot接口參數的默認值與必要性最佳實踐記錄

    這篇文章主要介紹了SpringBoot接口參數的默認值與必要性,通過合理設置接口參數的默認值和必要性,我們可以創(chuàng)建出既健壯又靈活的?RESTful?API,需要的朋友可以參考下
    2024-08-08
  • java多線程使用mdc追蹤日志方式

    java多線程使用mdc追蹤日志方式

    這篇文章主要介紹了java多線程使用mdc追蹤日志方式,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2021-09-09
  • spring-gateway網關聚合swagger實現多個服務接口切換的示例代碼

    spring-gateway網關聚合swagger實現多個服務接口切換的示例代碼

    這篇文章主要介紹了spring-gateway網關聚合swagger實現多個服務接口切換的示例代碼,本文給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2022-03-03
  • Springboot集成ClickHouse及應用場景分析

    Springboot集成ClickHouse及應用場景分析

    這篇文章主要介紹了Springboot集成ClickHouse的實例代碼,本文通過應用場景實例代碼介紹了整合springboot的詳細過程,感興趣的朋友跟隨小編一起看看吧
    2022-02-02
  • 基于Map的computeIfAbsent的使用場景和使用方式

    基于Map的computeIfAbsent的使用場景和使用方式

    這篇文章主要介紹了基于Map的computeIfAbsent的使用場景和使用方式,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2021-09-09
  • 使用@Service注解出現No bean named 'xxxx' available]錯誤的解決

    使用@Service注解出現No bean named 'xxxx'&

    這篇文章主要介紹了使用@Service注解出現No bean named 'xxxx' available]錯誤的解決方案,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教
    2023-08-08
  • 關于replaceFirst使用時的注意事項

    關于replaceFirst使用時的注意事項

    這篇文章主要介紹了關于replaceFirst使用時的注意事項,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-03-03

最新評論