1、缓存重复用到的对象
利用缓存,其实我不说大家也都知道,在平时项目中用到多次的对象也会进行缓存,谁也不会多次去创建。
但是,这一点在反射中尤为重要,比如Class.forName
方法,我们做个测试:
long startTime = System.currentTimeMillis();
Class clz = Class.forName("com.example.studynote.reflection.User");
User user;
int i = 0;
while (i < 1000000) {
i++;
//方法1,直接实例化
user = new User();
//方法2,每次都通过反射获取class,然后实例化
user = (User) Class.forName("com.example.studynote.reflection.User").newInstance();
//方法3,通过之前反射得到的class进行实例化
user = (User) clz.newInstance();
}
System.out.println("耗时:" + (System.currentTimeMillis() - startTime));
打印结果:
1、直接实例化
耗时:15
2、每次都通过反射获取class,然后实例化
耗时:671
3、通过之前反射得到的class进行实例化
耗时:31
所以看出来,只要我们合理的运用这些反射方法,比如Class.forName,Constructor,Method,Field
等,尽量在循环外就缓存好实例,就能提高反射的效率,减少耗时。
2、setAccessible(true)
之前我们说过当遇到私有变量和方法的时候,会用到setAccessible(true)
方法关闭安全检查。这个安全检查其实也是耗时的。
所以我们在反射的过程中可以尽量调用setAccessible(true)
来关闭安全检查,无论是否是私有的,这样也能提高反射的效率。