java反射耗時(shí)測(cè)試案例解析
java反射相對(duì)與普通的對(duì)象調(diào)用原理上來(lái)說(shuō)更加耗時(shí),在調(diào)用次數(shù)較少的情況下可忽略性能損失,但當(dāng)調(diào)用次數(shù)非常多時(shí),需要考慮到此問(wèn)題,即調(diào)用次數(shù)過(guò)多時(shí)不宜使用反射,以下舉例:
package com.test.reflection; import java.lang.reflect.Method; public class ReflectionDemo { public static void main(String[] args) throws Exception { // 常規(guī)方式 Student student = new Student(); long startNormal = System.currentTimeMillis(); for (int i = 0; i < 1000000; i++) { student.setName("hello"); } System.out.println("timeNormal=" + (System.currentTimeMillis() - startNormal)); //反射方式 Class<?> cla=Class.forName("com.test.reflection.Student"); long startReflection = System.currentTimeMillis(); for (int i = 0; i < 1000000; i++) { Method method=cla.getDeclaredMethod("setName", String.class); method.invoke(cla.newInstance(), "hello"); } System.out.println("timeReflection=" + (System.currentTimeMillis() - startReflection)); } }
運(yùn)行結(jié)果:
timeNormal=8 timeReflection=537
這是在簡(jiǎn)單使用反射調(diào)用某個(gè)方法的場(chǎng)景下1000000調(diào)用的性能差距。
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
使用Log4j2代碼方式配置實(shí)現(xiàn)線程級(jí)動(dòng)態(tài)控制
這篇文章主要介紹了使用Log4j2代碼方式配置實(shí)現(xiàn)線程級(jí)動(dòng)態(tài)控制,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2021-12-12高分面試分析jvm如何實(shí)現(xiàn)多態(tài)
這篇文章主要介紹了講解了在面試中jvm如何實(shí)現(xiàn)多態(tài),怎樣回答才能得到高分的問(wèn)題分析,有需要的朋友可以借鑒參考下,祝大家早日升職加薪多多進(jìn)步2022-01-01Java 信息摘要加密MD2、MD4、MD5實(shí)現(xiàn)詳解
這篇文章主要介紹了Java 信息摘要加密MD2、MD4、MD5實(shí)現(xiàn)詳解,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2019-07-07SpringBoot導(dǎo)入mail依賴報(bào)錯(cuò)問(wèn)題解決
這篇文章主要介紹了SpringBoot導(dǎo)入mail依賴報(bào)錯(cuò)問(wèn)題解決,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2019-10-10spring boot自定義log4j2日志文件的實(shí)例講解
下面小編就為大家分享一篇spring boot自定義log4j2日志文件的實(shí)例講解,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2017-11-11Java實(shí)現(xiàn)多線程大批量同步數(shù)據(jù)(分頁(yè))
這篇文章主要為大家詳細(xì)介紹了Java實(shí)現(xiàn)多線程大批量同步數(shù)據(jù)(分頁(yè)),文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2022-08-08