具体的关于反射的介绍可以参考我的另外一篇博文《深入解析java反射》。
反射的意义是什么,其实就是为了代码简洁,提高代码的复用率,外部调用方便,源代码,反编译都能看到。
某些情况下解耦用反射要清晰很多,下面是简单的测试
1 package cn.yonyong.reflection.testdemo; 2 3 interface Fruit { //水果接口 4 public void eat() ; //吃水果 5 } 6 7 class Apple implements Fruit{ //定义苹果 8 public void eat() { 9 System.out.println("**吃苹果。"); 10 } 11 } 12 13 class Orange implements Fruit{ 14 public void eat() { 15 System.out.println("**吃橘子。"); 16 } 17 } 18 19 class Factory{ 20 public static Fruit getInstance(String className){ 21 Fruit fruit = null ; 22 try{ 23 fruit = (Fruit) Class.forName(className).newInstance() ; 24 }catch(Exception e ){ 25 e.printStackTrace() ; 26 } 27 return fruit ; 28 } 29 } 30 31 public class FactoryDemo{ 32 public static void main(String args[]){ 33 //通过工厂类取得接口实例,传入完整的包.类名称 34 Fruit f = Factory.getInstance("cn.yonyong.reflection.testdemo.Apple") ; 35 if(f!=null){ //判断是否取得接口实例 36 f.eat() ; 37 } 38 } 39 }
输出:
**吃苹果。
如果不用反射,那么我们如果再加一个西瓜类,就得在Factory里判断,每添加一个类都要修改一次Factory,但用了反射只用在调用的时候传入完整的类名就可完成。结果:用反射,修改一处代码;不用反射,修改两处代码。
但是,我们知道java面向对象主要有四大特性:
封装、抽象、继承和多态。
封装:在面向对象语言中,封装特性是由类来体现的,我们将现实生活中的一类实体定义成类,其中包括属性和行为(在Java中就是方法),就好像人类,可以具有name,sex,age等属性,同时也具有eat(),sleep()等行为,我们在行为中实现一定的功能,也可操作属性,这是面向对象的封装特性;
抽象:抽象就是将一类实体的共同特性抽象出来,封装在一个抽象类中,所以抽象在面向对象语言是由抽象类来体现的。比如鸟就是一个抽象实体,因为抽象实体并不是一个真正的对象,它的属性还不能完全描述一个对象,所以在语言中体现为抽象类不能实例化;
继承:继承就像是我们现实生活中的父子关系,儿子可以遗传父亲的一些特性,在面向对象语言中,就是一个类可以继承另一个类的一些特性,从而可以代码重用,其实继承体现的是is-a关系,父类同子类在本质上还是一类实体;
多态:多态就是通过传递给父类对象引用不同的子类对象从而表现出不同的行为 ...
那么既然Java反射可以访问和修改私有成员变量,那封装成private还有意义么?
既然小偷可以访问和搬走私有成员家具,那封装成防盗门还有意义么?这是一样的道理,并且Java从应用层给我们提供了安全管理机制——安全管理器,每个Java应用都可以拥有自己的安全管理器,它会在运行阶段检查需要保护的资源的访问权限及其它规定的操作权限,保护系统免受恶意操作攻击,以达到系统的安全策略。所以其实反射在使用时,内部有安全控制,如果安全设置禁止了这些,那么反射机制就无法访问私有成员。
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】凌霞软件回馈社区,博客园 & 1Panel & Halo 联合会员上线
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】博客园社区专享云产品让利特惠,阿里云新客6.5折上折
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步