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