java技巧:反射判斷field類型的操作
JAVA 反射機(jī)制中,F(xiàn)ield的getModifiers()方法返回int類型值表示該字段的修飾符。
其中,該修飾符是java.lang.reflect.Modifier的靜態(tài)屬性。
對(duì)應(yīng)表如下:

//判斷是不是private類型方法
public static boolean is Private(int modifiers){
retrurn ((modifiers & 0x2)!=0);
}
分析一下,&是按位與操作符,0x2是十六進(jìn)制,二進(jìn)制是10,所以只有private類型按位與不為0.
補(bǔ)充:java反射獲取類的類名、屬性名、屬性類型、方法、執(zhí)行方法、構(gòu)造函數(shù)
public class Demo02 {
@SuppressWarnings("all")
public static void main(String[] args) throws Exception {
// 另一個(gè)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這個(gè)方法,如果沒有參數(shù),就默認(rèn)為null
// 獲取構(gòu)造方法
User u1 = (User) clazz.newInstance(); // 獲取無參的構(gòu)造函數(shù)這里的前提的保證類中應(yīng)該有無參的構(gòu)造函數(shù)
// 獲取參數(shù)為(int,String,int)的構(gòu)造函數(shù)
Constructor c2 = clazz.getDeclaredConstructor(int.class, String.class, int.class);
// 通過有參構(gòu)造函數(shù)創(chuàng)建對(duì)象
User u2 = (User) c2.newInstance(1001, "小小", 18);
// 通過反射調(diào)用普通方法
User u3 = (User) clazz.newInstance();
Method method03 = clazz.getDeclaredMethod("setId", int.class);
method.invoke(u3, 1002); // 把對(duì)象u3的id設(shè)置為1002
// 通過反射操作普通的屬性
User u4 = (User) clazz.newInstance();
Field f = clazz.getDeclaredField("name");
f.setAccessible(true); // 設(shè)置屬性可以直接的進(jìn)行訪問
f.set(u4, "石頭");
} catch (ClassNotFoundException e) {
e.printStackTrace();
}
}
}
public static void getObjectValue(Object object) throws Exception {
//我們項(xiàng)目的所有實(shí)體類都繼承BaseDomain (所有實(shí)體基類:該類只是串行化一下)
//不需要的自己去掉即可
if (object != null && object instanceof BaseDomain) {//if (object!=null ) ----begin
// 拿到該類
Class<?> clz = object.getClass();
// 獲取實(shí)體類的所有屬性,返回Field數(shù)組
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方法
/**
* 這里需要說明一下:他是根據(jù)拼湊的字符來找你寫的getter方法的
* 在Boolean值的時(shí)候是isXXX(默認(rèn)使用ide生成getter的都是isXXX)
* 如果出現(xiàn)NoSuchMethod異常 就說明它找不到那個(gè)gettet方法 需要做個(gè)規(guī)范
*/
Method m = (Method) object.getClass().getMethod(
"get" + getMethodName(field.getName()));
String val = (String) m.invoke(object);// 調(diào)用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 基本數(shù)據(jù)類型不一樣 這里有點(diǎn)說名如果定義名是 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);
}
}
// 如果還需要其他的類型請(qǐng)自己做擴(kuò)展
}//for() --end
}//if (object!=null ) ----end
}
// 把一個(gè)字符串的第一個(gè)字母大寫、效率是最高的、
private static String getMethodName(String fildeName) throws Exception{
byte[] items = fildeName.getBytes();
items[0] = (byte) ((char) items[0] - 'a' + 'A');
return new String(items);
}
以上為個(gè)人經(jīng)驗(yàn),希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。
相關(guān)文章
SpringSecurity Jwt Token 自動(dòng)刷新的實(shí)現(xiàn)
這篇文章主要介紹了SpringSecurity Jwt Token 自動(dòng)刷新的實(shí)現(xiàn),文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2020-06-06
java中常見XML解析器的使用詳解(JAXP,DOM4J,Jsoup,JsoupXPath)
為了處理和操作XML數(shù)據(jù),我們需要使用XML解析器,本文將介紹幾種常用的XML解析器,包括JAXP、DOM4J、Jsoup和JsoupXPath,需要的小伙伴可以參考一下2023-11-11
Java?實(shí)現(xiàn)使用Comparable按照我們指定的規(guī)則排序
這篇文章主要介紹了Java?如何使用Comparable按照我們指定的規(guī)則排序,通過練習(xí)創(chuàng)建TreeSet集合使用無參構(gòu)造方法,并按照年齡從小到大的順序排序,若年齡相同再按照姓名的字母順序排序展開內(nèi)容,需要的朋友可以參考一下2022-04-04
SpringBoot接口參數(shù)的默認(rèn)值與必要性最佳實(shí)踐記錄
這篇文章主要介紹了SpringBoot接口參數(shù)的默認(rèn)值與必要性,通過合理設(shè)置接口參數(shù)的默認(rèn)值和必要性,我們可以創(chuàng)建出既健壯又靈活的?RESTful?API,需要的朋友可以參考下2024-08-08
spring-gateway網(wǎng)關(guān)聚合swagger實(shí)現(xiàn)多個(gè)服務(wù)接口切換的示例代碼
這篇文章主要介紹了spring-gateway網(wǎng)關(guān)聚合swagger實(shí)現(xiàn)多個(gè)服務(wù)接口切換的示例代碼,本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2022-03-03
Springboot集成ClickHouse及應(yīng)用場(chǎng)景分析
這篇文章主要介紹了Springboot集成ClickHouse的實(shí)例代碼,本文通過應(yīng)用場(chǎng)景實(shí)例代碼介紹了整合springboot的詳細(xì)過程,感興趣的朋友跟隨小編一起看看吧2022-02-02
基于Map的computeIfAbsent的使用場(chǎng)景和使用方式
這篇文章主要介紹了基于Map的computeIfAbsent的使用場(chǎng)景和使用方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2021-09-09
使用@Service注解出現(xiàn)No bean named 'xxxx'&
這篇文章主要介紹了使用@Service注解出現(xiàn)No bean named 'xxxx' available]錯(cuò)誤的解決方案,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2023-08-08
關(guān)于replaceFirst使用時(shí)的注意事項(xiàng)
這篇文章主要介紹了關(guān)于replaceFirst使用時(shí)的注意事項(xiàng),具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2022-03-03

