Java反射獲取實(shí)例的速度對比分析
之前代碼有一個(gè)邏輯,是在初始化時(shí)讀取某個(gè)包下的所有class文件,放入到一個(gè)HashMap里。代碼運(yùn)行過程中,通過Key獲取到對應(yīng)class的全路徑名,最后通過Class.forName(className).getDeclaredConstructor().newInstance()獲取實(shí)例對象。
后來同事看到了代碼,對這個(gè)HashMap里存儲(chǔ)方式提出了建議,之前的Map是<String,String>完全可以改成<String,Class>
后來我測試了一下兩者實(shí)例化一個(gè)對象的速度:
public static void main(String[] args) {
try {
int MAX = 100000;
for (int count = 0; count < 50; count++) {
System.out.println("====第" + count+"次");
long s1 = System.currentTimeMillis();
for (int i = 0; i < MAX; i++) {
Person o = (Person)Class.forName("com.qingtai.domin.Person").newInstance();
}
long e1 = System.currentTimeMillis();
System.out.println("1_duration:" + (e1 - s1));
long s2 = System.currentTimeMillis();
Class clazz = Class.forName("com.qingtai.domin.Person");
for (int i = 0; i < MAX; i++) {
Person person = (Person) clazz.newInstance();
}
long e2 = System.currentTimeMillis();
System.out.println("2_duration:" + (e2 - s2));
}
} catch (Exception e) {
e.printStackTrace();
}
}
輸出:
====第39次 1_duration:72 2_duration:3 ====第40次 1_duration:79 2_duration:12 ====第41次 1_duration:92 2_duration:8 ====第42次 1_duration:80 2_duration:5
結(jié)論:
Map的value不存儲(chǔ)全路徑名,在初始化的時(shí)候Map的value直接存儲(chǔ)Class對象,在反射過程中速度提升很大。
補(bǔ)充知識(shí):java反射獲取類實(shí)例并調(diào)用私有方法
我就廢話不多說了,大家還是直接看代碼吧~
public class TestReflect {//測試類
public void mPublic() {//訪問權(quán)限最大
System.out.println("public run");
}
protected void mProtected() {//同包下才能訪問(實(shí)驗(yàn)對象)
System.out.println("protected run");
}
private void mPrivate() {//只有本類中才能訪問(實(shí)驗(yàn)對象)
System.out.println("private run");
}
}
public static void main(String[] args) throws Exception {
Class<?> class1 = null;
// 反射獲取類實(shí)例,用的最多的就是jdbc獲取驅(qū)動(dòng)的時(shí)候就是用Class.forName("xxx");
// 一般采用這種形式
class1 = Class.forName("com.xxx.TestReflect");
// class1 = new TestReflect().getClass();
// class1 = TestReflect.class;
// 類實(shí)例化,到這里就可以訪問TestReflect類的public屬性的成員方法和成員變量了
TestReflect tr = (TestReflect) class1.newInstance();
// 通過java.lang.Class類得到一個(gè)Method對象
// api中java.lang.Class.getDeclaredMethod方法介紹
// 返回一個(gè) Method 對象,該對象反映此 Class 對象所表示的類或接口的指定已聲明方法。
Method method = class1.getDeclaredMethod("mPrivate");
Method method1 = class1.getDeclaredMethod("mProtected");
//將此對象的 accessible 標(biāo)志設(shè)置為指示的布爾值。
//值為 true 則指示反射的對象在使用時(shí)應(yīng)該取消 Java 語言訪問檢查。
//值為 false 則指示反射的對象應(yīng)該實(shí)施 Java 語言訪問檢查。
method.setAccessible(true);
method1.setAccessible(true);
// 調(diào)用該方法
method.invoke(tr);
method1.invoke(tr);
}
以上這篇Java反射獲取實(shí)例的速度對比分析就是小編分享給大家的全部內(nèi)容了,希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。
相關(guān)文章
關(guān)于Logback+MyBatis日志輸出問題的一些思考
這篇文章主要介紹了關(guān)于Logback+MyBatis日志輸出問題的一些思考,具有很好的參考價(jià)值,希望對大家有所幫助,2023-09-09
Springboot實(shí)現(xiàn)多數(shù)據(jù)源切換詳情
這篇文章主要介紹了Springboot實(shí)現(xiàn)多數(shù)據(jù)源切換詳情,文章圍繞主題展開詳細(xì)的內(nèi)容介紹,具有一定的參考價(jià)值,感興趣的朋友可以參考一下2022-09-09
SpringCloud學(xué)習(xí)筆記之SpringCloud搭建父工程的過程圖解
SpringCloud是分布式微服務(wù)架構(gòu)的一站式解決方案,十多種微服務(wù)架構(gòu)落地技術(shù)的集合體,俗稱微服務(wù)全家桶,這篇文章主要介紹了SpringCloud學(xué)習(xí)筆記(一)搭建父工程,需要的朋友可以參考下2021-10-10
SpringBoot使用前綴樹實(shí)現(xiàn)敏感詞過濾示例
最近項(xiàng)目用到了敏感詞過濾,本文主要就來介紹一下SpringBoot使用前綴樹實(shí)現(xiàn)敏感詞過濾示例,具有一定的參考價(jià)值,感興趣的可以了解一下2023-10-10
Spring中@PathVariable和@RequestParam注解的用法區(qū)別
這篇文章主要介紹了Spring中@PathVariable和@RequestParam注解的用法區(qū)別,@PathVariable 是 Spring 框架中的一個(gè)注解,用于將 URL 中的變量綁定到方法的參數(shù)上,它通常用于處理 RESTful 風(fēng)格的請求,從 URL 中提取參數(shù)值,并將其傳遞給方法進(jìn)行處理,需要的朋友可以參考下2024-01-01

