激情久久久_欧美视频区_成人av免费_不卡视频一二三区_欧美精品在欧美一区二区少妇_欧美一区二区三区的

服務(wù)器之家:專注于服務(wù)器技術(shù)及軟件下載分享
分類導(dǎo)航

PHP教程|ASP.NET教程|Java教程|ASP教程|編程技術(shù)|正則表達式|C/C++|IOS|C#|Swift|Android|VB|R語言|JavaScript|易語言|vb.net|

服務(wù)器之家 - 編程語言 - Java教程 - Java如何基于反射機制獲取不同的類

Java如何基于反射機制獲取不同的類

2020-08-13 00:21whyha Java教程

這篇文章主要介紹了Java如何基于反射機制獲取不同的類,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友可以參考下

什么是反射機制

Java的反射(reflection)機制是指在程序的運行狀態(tài)中,可以構(gòu)造任意一個的對象,可以了解任意一個對象所屬的類,可以了解任意一個類的成員變量和方法,可以調(diào)用任意一個對象的屬性和方法。這種動態(tài)獲取程序信息以及動態(tài)調(diào)用對象的功能稱為Java語言的反射機制。反射被視為動態(tài)語言的關(guān)鍵(在運行階段可以改變其結(jié)構(gòu))

特點:

1、極大的提高了程序的靈活性和擴展性,降低模塊的耦合性,提高自身的適應(yīng)能力

2、通過反射機制可以讓程序創(chuàng)建和控制任何類的對象,無需提前硬編碼目標類

3、能夠在運行時構(gòu)造一個類的對象、判斷一個類所具有的成員變量和方法、調(diào)用一個對象的方法(包括 private),可能會有安全隱患

4、是構(gòu)建框架技術(shù)的基礎(chǔ)所在,使用反射可以避免將代碼寫死在框架中

5、包含動態(tài)類型,而 JVM 不能對動態(tài)代碼優(yōu)化,所以效率會比較低

在Java中可以通過Reflection APIs在運行時動態(tài)生成class實體,通過Constructor創(chuàng)建類實例、Field訪問成員屬性、Method調(diào)用方法

Class類

在Java中,每個 class 都有一個相應(yīng)的 Class 對象。在編譯完成后,在生成的.class文件中,會產(chǎn)生一個Class對象,用于表示這個類的類型信息。

特點:

1、由系統(tǒng)創(chuàng)建Class類

2、同一個類的實例指向同一個Class對象

3、通過Class可以完整的得到一個類所有被加載的結(jié)構(gòu)

4、Class類是Java反射的基礎(chǔ)

獲得Class類的方法:

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
public class MyReflect {
  public static void main(String[] args) throws ClassNotFoundException {
    Teacher t = new Teacher();
    // 1、通過對象獲得
    Class c1 = t.getClass();
    // 2、forName + 全限定名 獲得
    Class c2 = Class.forName("reflect.Teacher");
    // 3、通過類名獲得
    Class c3 = Teacher.class;
    // 4、基本數(shù)據(jù)類型的Type屬性獲得
    Class c4 = Double.TYPE;
    // 5、通過子類的Class對象獲得
    Class c5 = c1.getSuperclass();
  }
}
class Person {
  String name;
  public Person() {
  }
}
class Teacher extends Person {
  public Teacher() {
  }
}

Java如何基于反射機制獲取不同的類

getXXX為獲取 public 構(gòu)造器、屬性、方法

getDeclaredXXX 獲取任意構(gòu)造器、屬性、方法(包括private)

setAccessible方法避開權(quán)限檢測,用以訪問權(quán)限不足的成員

以下不在贅述

準備:Person類以及Tercher子類

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
package reflect;
 
class Person {
  public String name;
  private int age;
 
  public String getName() {
    return name;
  }
 
  public void setName(String name) {
    this.name = name;
  }
 
  public int getAge() {
    return age;
  }
 
  public void setAge(int age) {
    this.age = age;
  }
 
  public Person() {
  }
 
  public Person(String name, int age) {
    this.name = name;
    this.age = age;
  }
 
  @Override
  public String toString() {
    return "Person{" +
        "name='" + name + '\'' +
        ", age=" + age +
        '}';
  }
 
  public String greet(String name) {
    return "hello " + name + ".";
  }
}
 
class Teacher extends Person {
 
}

Constructor類

java.lang.reflect.Constructor類是java.lang.reflect.Executable類的直接子類,用于表示類的構(gòu)造方法。通過Class對象的 getConstructors() 方法可以獲得當前運行時類的構(gòu)造方法

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
public class MyConstructor {
  public static void main(String[] args) throws Exception {
    Class<Person> c = (Class<Person>) Class.forName("reflect.Person");
 
//    Object person2 = c.newInstance();  //@Deprecated
//    System.out.println(person2);
    Constructor<Person> constructor = c.getConstructor();
    Person person = constructor.newInstance();
    System.out.println(person);
 
    // 獲取 public 有參構(gòu)造方法
    Constructor<Person> constructor1 = c.getConstructor(String.class, int.class);
    Person person1 = constructor1.newInstance("JL", 18);
    System.out.println(person1);
 
    // 獲取構(gòu)造方法
    Constructor<Person> constructor2 = c.getDeclaredConstructor(String.class, int.class);
    constructor2.setAccessible(true);
    Person person2 = constructor1.newInstance("JL", 18);
    System.out.println(person2.name);
  }
}

Field類

java.lang.reflect.Field類用于封裝成員變量信息,調(diào)用Class對象的 getField() 或 getFields()等方法可以獲得當前運行時類的成員變量

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
public class MyField {
  public static void main(String[] args) throws Exception {
    Class<?> c = Class.forName("reflect.Person");
    // 在Person類中,無參的構(gòu)造方法不能省略
    Object p = c.getConstructor().newInstance();
 
    // 獲取 public 成員變量
    Field[] fields = c.getFields();
    // 獲取所有成員變量(包括 private)
    Field[] allFields = c.getDeclaredFields();
    //獲取指定名稱public變量
    Field f1 = c.getField("name");
    // 成員變量set、get
    f1.set(p, "JL");
    System.out.println(f1.get(p));
 
    Field f2 = c.getDeclaredField("age");  // private int age
    // 忽略權(quán)限檢查,使得 private 成員可以被訪問
    f2.setAccessible(true);
    f2.set(p, 18);
    System.out.println(f2.get(p));
  }
}

Method類

java.lang.reflect.Method類是java.lang.reflect.Executable類的直接子類,用于封裝成員方法的信息,調(diào)用Class對象的 getMethod() 方法或 getMethods() 方法可以獲得當前運行時類的指定方法或所有方法

?
1
2
3
4
5
6
7
8
9
10
11
12
13
public class MyMethod {
   public static void main(String[] args) throws Exception {
     Class<Person> c = (Class<Person>) Class.forName("reflect.Person");
     Person p = c.getConstructor().newInstance();
     // 獲取所有 public 方法
     Method[] methods = c.getMethods();
     // 獲取 greet 方法
     Method method1 = c.getMethod("greet", String.class);
     //執(zhí)行 greet 方法
     System.out.println(method1.invoke(p, "JL"));
   }
 }
0

PS:主要簡單說明反射的使用,關(guān)于類加載機制,性能分析等沒有說明

以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持服務(wù)器之家。

原文鏈接:https://www.cnblogs.com/whyha/p/13376827.html

延伸 · 閱讀

精彩推薦
主站蜘蛛池模板: 亚洲性一区 | 国产精品一区在线看 | 精品久久久久久亚洲精品 | 亚洲福利视 | 91在线视频免费观看 | 久久草在线观看视频 | 成人爽a毛片免费啪啪红桃视频 | 亚洲免费视频一区 | 羞羞视频2023 | 97青青草视频 | 欧美成人免费电影 | 日韩美香港a一级毛片免费 日韩激情 | 日本a v免费观看 | 国产中出视频 | 麻豆91精品91久久久 | h网站在线观看 | 国产成年人网站 | 一本色道久久综合亚洲精品小说 | 1024亚洲天堂 | 久久精品国产清自在天天线 | 蜜桃网在线观看 | 国产在线观看福利 | 亚洲一区 国产 | 康妮卡特欧美精品一区 | 毛片视频播放 | 一级α片免费看刺激高潮视频 | chinesexxxx刘婷hd| 91免费高清视频 | 狠狠ri | 日日操日日操 | 午夜精品久久久久久久久久久久久蜜桃 | 国产精品一二三区 | 毛片在线免费 | 欧美成人高清视频 | 蜜桃网在线 | 中国毛片在线观看 | 综合激情网 | 一级成人毛片 | 精品在线观看一区 | 蜜桃视频在线免费观看 | 亚洲国产精品高潮呻吟久久 |