成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

測試開發必須掌握的知識點:Java反射

開發 前端
Java反射是Java被視為動態(或準動態)語言的一個關鍵性質。這個機制允許程序在運行時通過Reflection APIs取得任何一個已知名稱的class的內部信息以及任意一個對象的內部信息。

 Spring 在創建 Bean 實例和依賴注入以及AOP時都使用了反射,今天我們就來講解一下反射的概念以及其應用。

[[391520]]

反射機制

Java反射是Java被視為動態(或準動態)語言的一個關鍵性質。這個機制允許程序在運行時通過Reflection APIs取得任何一個已知名稱的class的內部信息以及任意一個對象的內部信息。Java反射機制提供如下功能:

在運行時判斷任意一個對象所屬的類

在運行時構造任意一個類的對象

在運行時判斷任意一個類所具有的成員變量和方法

在運行時調用任一個對象的方法

在運行時創建新類對象

在使用Java的反射功能時,基本首先都要獲取類的Class對象,再通過Class對象獲取其他的對象。大家都知道,在Junit4中注解@Test表示測試用例,每一個測試用例的本質就是測試類中的一個方法,即:

  1. @Test 
  2.     public void test() { 
  3.         fail("Not yet implemented"); 
  4.     } 

 我們知道,通常情況下,調用一個類的方法是,先對類進行實例化,記為obj,然后通過obj.test()的方式調用。在這里我們思考一個問題,Junit4是一個框架,在運行的過程中,框架根本不知道用戶定義了多少個測試用例(雖然通過@Test進行了約束),顯然框架是在運行的時候才確認了測試用例,并通過某種方式調用了測試用例,這就是反射的本質——在運行時工作!

Class類和Class實例

我們知道Java中的類是一個模板,它描述一類對象的行為和狀態,例如:

  1. class Person{ 
  2. Person kevin=new Person(); 
  3. Person mike=new Person(); 

 Person就是Kevin、Mike這兩個對象的類型,即是Kevin和Mike兩個對象的描述。

Java中一切皆對象,那么Person(自定義類)、String(JDK提供的類)...又是什么類型呢?他們都是Class類的對象,都由Class類來描述。

Class的實例是什么?是類或接口,更嚴格地說是java中的字節碼(類或接口編譯后生成的.class文件)。

常用API介紹

在這里我們重點介紹反射技術中關于獲取Class對象,訪問字段,調用方法以及調用構造方法的API

1.獲取類的Class對象

Class(java.lang.Class) 類的實例表示正在運行的 Java 應用程序中的類和接口。這個Class實例是JVM內部創建的,如果我們查看JDK源碼,可以發現Class類的構造方法是private,只有JVM能創建Class實例,我們自己的Java程序是無法創建Class實例的。由于JVM為每個加載的class創建了對應的Class實例,并在實例中保存了該class的所有信息,包括類名、包名、父類、實現的接口、所有方法、字段等,因此,如果獲取了某個Class實例,我們就可以通過這個Class實例獲取到該實例對應的class的所有信息。獲取類的Class對象有多種方式:

2、獲取類的Fields

可以通過反射機制得到某個類的某個屬性,然后改變對應于這個類的某個實例的該屬性值。JAVA 的Class類提供了幾個方法獲取類的屬性。

3.獲取類的Method

通過反射機制得到某個類的某個方法,然后調用對應于這個類的某個實例的該方法,Class類提供了幾個方法獲取類的方法。

4.獲取類的Constructor

通過反射機制得到某個類的構造器,然后調用該構造器創建該類的一個實例,Class類提供了幾個方法獲取類的構造器。

反射API應用

寫一個類

  1. public class ReflectDemo { 
  2.        ReflectDemo(){     
  3.               System.out.println("默認構造函數"); 
  4.        } 
  5.        ReflectDemo(String p_para){       
  6.               System.out.println("有參構造函數"); 
  7.        } 
  8.        public String myPara1="public屬性"
  9.        protected String myPara2="protected屬性"
  10.        private String myPara3="private屬性"
  11.        public void test1(){ 
  12.               System.out.println("這是 public void 無參方法test1"); 
  13.        } 
  14.        protected String test2(String p_test2){ 
  15.               System.out.println("這是 protected void 有參方法test2"); 
  16.               returnp_test2; 
  17.        } 
  18.        private void test3(){ 
  19.               System.out.println("這是 privated 無參方法test3"); 
  20.        } 

 新建類實例

調用類的Class對象的newInstance方法,該方法會調用對象的默認構造器,如果沒有默認構造器,會調用失敗,代碼如下:

  1. Class classType =ReflectDemo.class; 
  2. Object inst = classType.newInstance(); 
  3. System.out.println(inst); 

 調用默認Constructor對象的newInstance方法,代碼如下:

  1. Class classType =ReflectDemo.class; 
  2. Constructor constructor1 = classType.getConstructor(); 
  3. Object inst = constructor1.newInstance(); 
  4. System.out.println(inst); 

 調用帶參數Constructor對象的newInstance方法,代碼如下:

  1. Constructor constructor2 =ReflectDemo.class.getDeclaredConstructor(String.class); 
  2. Object inst = constructor2.newInstance("test"); 
  3. System.out.println(inst); 

 調用方法

通過反射獲取類Method對象,獲取類中的所有函數。

  1. String className = "com.lesson.reflect.ReflectDemo";        
  2. Class clas = Class.forName(className); 
  3. Method[] a=clas.getDeclaredMethods(); 
  4. for(int i=0;i<a.length;i++){ 
  5.        System.out.println(a[i].toString()); 

 通過反射獲取類Method對象,調用method的Invoke方法調用函數。

調用protected有參方法 ,有參方法

  1. Class simpleClass = Class.forName("com.lesson.reflect.ReflectDemo"); 
  2. Object simpelObject = simpleClass.newInstance(); 
  3. Method simpleMethod =simpleClass.getDeclaredMethod("test2",  String.class); 
  4. simpleMethod.invoke(simpelObject, "Hello,world"); 

 調用private方法,有參方法

  1. Class simpleClass2 = Class.forName("com.lesson.reflect.ReflectDemo"); 
  2. Object simpelObject2 = simpleClass2.newInstance(); 
  3. Method simpleMethod2 = simpleClass2.getDeclaredMethod("test3",   String.class); 
  4. simpleMethod2.setAccessible(true); 
  5. simpleMethod2.invoke(simpelObject2, "Hello,world"); 

 調用public,無參方法

  1. Class simpleClass3 = Class.forName("com.lesson.reflect.ReflectDemo"); 
  2. Object simpelObject3 =simpleClass3.newInstance();              
  3. Method simpleMethod3 =simpleClass3.getDeclaredMethod("test1"); 
  4. simpleMethod3.invoke(simpelObject3); 

 設置讀取屬性

通過反射獲取類的Field對象,調用Field中的方法設置或獲取值

設置或獲取private變量

  1. ReflectDemo t =new ReflectDemo(); 
  2. Class temp = t.getClass(); 
  3. Field f; 
  4. f = temp.getDeclaredField("myPara3"); 
  5. f.setAccessible(true);  
  6. System.out.println(f.get(t)); 
  7. f.set(t, "新的private屬性"); 
  8. System.out.println(f.get(t)); 

 好了,這就是反射的基礎API使用方法,可能大家還是不能夠理解其在實際工作中的應用價值.

 

責任編輯:姜華 來源: 今日頭條
相關推薦

2021-04-13 08:25:12

測試開發Java注解Spring

2016-12-21 09:55:55

面試JavaScrip總結

2021-01-18 10:33:53

Java反射模塊

2019-08-15 09:35:03

2021-05-17 06:02:58

Css前端CSS 特效

2009-04-01 11:39:39

視圖DB2

2020-10-14 11:06:29

Java

2021-12-31 08:18:43

Java 測試開發 Java 基礎

2021-06-29 15:56:39

MYSQL開發數據庫

2019-07-19 16:15:20

Java日志命令

2018-06-12 15:55:07

編程語言Java加密方式

2018-01-29 15:23:14

網絡知識點軟件測試

2024-06-04 14:07:00

2020-06-19 16:25:19

MySQL日志文件數據庫

2014-06-10 13:44:58

iOSUIImage知識點

2020-09-25 16:52:57

Python

2020-09-28 08:54:51

python

2025-05-07 08:55:00

2011-04-15 12:25:21

BGP路由

2010-08-17 14:56:00

HCNE認證
點贊
收藏

51CTO技術棧公眾號

主站蜘蛛池模板: 99在线免费观看视频 | 精品区| 亚洲中国字幕 | 免费精品久久久久久中文字幕 | 超碰地址 | www.色综合 | 五月天天丁香婷婷在线中 | 国产成人综合亚洲欧美94在线 | 国产成人jvid在线播放 | 色橹橹欧美在线观看视频高清 | 99久久婷婷国产综合精品电影 | 亚洲一区二区三区四区五区中文 | av一级| 91麻豆精品国产91久久久久久 | 色婷婷综合网 | 91亚洲精品久久久电影 | 国产精品久久久久久久久久 | 欧美成人免费电影 | 国产日韩欧美在线一区 | 狠狠狠色丁香婷婷综合久久五月 | 九九热这里 | 日韩欧美视频免费在线观看 | 欧美一级久久久猛烈a大片 日韩av免费在线观看 | 亚洲a网 | 91av精品 | 亚洲欧美中文字幕在线观看 | 亚洲国产成人久久综合一区,久久久国产99 | 日韩精品一 | 精品国产乱码久久久 | 蜜桃av一区二区三区 | 久久99精品国产自在现线小黄鸭 | 国产精品成人免费 | а_天堂中文最新版地址 | av天天看 | 56pao在线| 日韩成人在线看 | 欧美不卡一区二区三区 | 天天av网 | 欧美精品在线播放 | 欧美a∨ | 888久久久|