`
summernight
  • 浏览: 74605 次
  • 性别: Icon_minigender_2
社区版块
存档分类
最新评论

对java反射机制的理解及帮助文档

阅读更多

     一直以来感觉“java反射机制”是个很神秘,至少是我一时半会搞不懂的东西。。。也因为这种一直报着害怕的感觉没敢深入学习,可是就是前几天因为看到“大话设计模式 之 小菜编程成长记”中讲的设计模式中讲到java反射,使得我不得不好好的学习下java反射,真正静下心来学习过后才发现原来java反射没有我想象的那么可怕,原来java已经给写好了反射的API,只要调用一切都可以得到。。。。

      首先什么是java反射?

      java反射是Java被视为动态(或准动态)语言的一个关键性质。这个机制允许程序在运行时透过Reflection APIs取得任何一个已知名称的class的内部信息,包括其modifiers(诸如public, static等等)、superclass(例如Object)、实现之interfaces(例如Cloneable),也包括fields和methods的所有信息,并可于运行时改变fields内容或唤起methods。

      下面我就通过例子来把我了解的java反射里的应用给罗列出来。。

/*
		 * 获得Class的方法有两种
		 * 一、.getClass()
		 * 二、Class.forName()
		 * */
		
		/*
		 * Class cla = "com.pac.Provider".getClass();
		 * System.out.println(cla.getPackage().getName());
		 * System.out.println(cla.getSuperclass().getName());
		 * System.out.println(cla.getInterfaces()[0].getName());
		 * Field[] fid = cla.getDeclaredFields();
		 * for(Object o:fid){
		 * 	Field fd = (Field)o;
		 * 	System.out.println(fd.getName());
		 * }
		 * 刚才是这样写的,输出的结果居然是:
		 * java.lang
		 * java.lang.Object
		 * java.io.Serializable
		 * value
		 * offset
		 * count
		 * hash
		 * serialVersionUID
		 * serialPersistentFields
		 * CASE_INSENSITIVE_ORDER
		 * 顿时超级郁闷。怎么我的父类和定义的属性都对不上,经过朋友的帮助突然毛塞顿开,原来"com.pac.Provider"这样写其实就是
		 * 对String的取得Class所得的数据,其实人家根据没有取错啊。。。只是我用错了。。。
		 * */
		Class cla = Provider.class;
		
		Class cla_s = null;
		try {
			cla_s = Class.forName("com.pac.Provider");//静态方式获取
		} catch (ClassNotFoundException e) {
			// TODO Auto-generated catch block
			e.printStackTrace();
		}
		
		System.out.println(cla.getPackage().getName());//获取Provider的包路径名称
		System.out.println(cla.getSuperclass().getName());//获取Provider的父类名称
		Class[] interfaces = cla.getInterfaces();
		for(Object o:interfaces){
			Class is =(Class)o;
			System.out.println(is.getName());//获取Provider的所有实现的接口的名称
		}
			
		
		Field[] fid = cla.getDeclaredFields();//获取Provider自身定义的属性名称,不论 public 或private 或其它类型皆可获得
		for(Object o:fid){
			Field fd = (Field)o;
			System.out.println(fd.getName());
		}
		
		Field[] fid_1 = cla.getFields();//获取Provider及父类定义的属性名称,只能获得public类型的属性
		for(Object o:fid_1){
			Field fd = (Field)o;
			System.out.println(fd.getName());
		}
		
		Method[] med = cla.getDeclaredMethods();//获取Provider类自身定义的所有方法,不论 public 或private 或其它类型皆可获得
		for(Object o:med){
			Method fd = (Method)o;
			System.out.println(Modifier.toString(fd.getModifiers())+" "+fd.getReturnType().getName()+" "+fd.getName()+"()");
		}
		
		Method[] med_d = cla.getMethods();//得到Provider及其父类以及父类的父类(以此类推)的所有的public方法,当然子类重写父类的方法的情况下只显示一次。
		for(Object o:med_d){
			Method fd = (Method)o;
			System.out.println(Modifier.toString(fd.getModifiers())+" "+fd.getReturnType().getName()+" "+fd.getName()+"()");
		}
		
		Constructor[] con = cla.getDeclaredConstructors();//获取Provider类自身定义的所有方法,不论 public 或private 或其它类型皆可获得
		for(Object o:con){
			Constructor fd = (Constructor)o;
			TypeVariable[] tv = fd.getTypeParameters();
			String para = "";
			for(Object otv:tv){
				TypeVariable v = (TypeVariable)otv;
				para += v.getName()+",";
			}
			para = para.length()==0?"":para.substring(0, para.length()-1);
			System.out.println("Constructor:"+Modifier.toString(fd.getModifiers())+" "+fd.getName()+"("+para+")");
		}
		
		Constructor[] con_c = cla.getConstructors();//获取Provider类自身定义的所有方法,不论 public 或private 或其它类型皆可获得
		for(Object o:con_c){
			Constructor fd = (Constructor)o;
			TypeVariable[] tv = fd.getTypeParameters();
			String para = "";
			for(Object otv:tv){
				TypeVariable v = (TypeVariable)otv;
				para += v.getName()+",";
			}
			para = para.length()==0?"":para.substring(0, para.length()-1);
			System.out.println("getConstructors:"+Modifier.toString(fd.getModifiers())+" "+fd.getName()+"("+para+")");
		}

 

 

           反射 的另三个动态性质: (1) 运行时生成 instances (2) 行期唤起 methods (3) 运行时改动 fields

 

 

try {
	cla.newInstance();//实例化这个类
} catch (InstantiationException e) {
	e.printStackTrace();
} catch (IllegalAccessException e) {	
	e.printStackTrace();
}

 

try {
			Class[] ptypes = new Class[2];
			ptypes[0] = Object.class;
			ptypes[1] = String.class;
			
			Method mm = cla.getDeclaredMethod("copy", ptypes);
			Provider pp = (Provider)cla.newInstance();
			Object ags[] = new Object[2];
			ags[0] = new Object();
			ags[1] = new String("Hello,world");
			mm.invoke(pp, ags);
		} catch (SecurityException e) {
			// TODO Auto-generated catch block
			e.printStackTrace();
		} catch (NoSuchMethodException e) {
			// TODO Auto-generated catch block
			e.printStackTrace();
		} catch (IllegalAccessException e) {
			// TODO Auto-generated catch block
			e.printStackTrace();
		} catch (InstantiationException e) {
			// TODO Auto-generated catch block
			e.printStackTrace();
		} catch (InvocationTargetException e) {
			// TODO Auto-generated catch block
			e.printStackTrace();
		}
 

 

//运行时变更fields内容
		try {
			Field code = cla.getDeclaredField("code");
			Field name = cla.getDeclaredField("name");
			
			Provider pp = (Provider)cla.newInstance();
			name.set(pp, "nameaaa");
			code.set(pp, "code1");
			System.out.println("code:"+pp.getCode());
			System.out.println("name:"+pp.getName());
			
		} catch (SecurityException e) {
			// TODO Auto-generated catch block
			e.printStackTrace();
		} catch (NoSuchFieldException e) {
			// TODO Auto-generated catch block
			e.printStackTrace();
		} catch (IllegalArgumentException e) {
			// TODO Auto-generated catch block
			e.printStackTrace();
		} catch (IllegalAccessException e) {
			// TODO Auto-generated catch block
			e.printStackTrace();
		} catch (InstantiationException e) {
			// TODO Auto-generated catch block
			e.printStackTrace();
		}
 

 

           在什么环境下使用 java反射?


           我想java反射在java的开源项目中真的用的好多,比如:spring的ioc,JDBC 的 classForName(),strut2中的配置文件的读取应该也是反射,等等。。。而且反射使得编程特别灵活,只要在运行状态下,你知道这个类的名称就可以得到你想到的任何东西,当然包括实例化。。。

分享到:
评论

相关推荐

    java面试题--反射机制

    ### Java反射机制详解 #### 一、引言 在Java面试中,经常会出现与反射...以上内容不仅解释了Java反射机制的相关知识点,还通过示例代码进行了实践演示,希望能够帮助你在Java面试中更好地理解和运用这一重要特性。

    java反射机制文档及代码

    在本资料"java反射机制文档及代码"中,详细介绍了Java反射的基础知识和常见应用。 首先,反射的核心类是`java.lang.Class`,它代表了运行时的类信息。通过Class对象,我们可以获取到类的名称、包名、属性、构造器、...

    Java反射机制Demo

    ### Java反射机制详解 #### 一、什么是Java反射机制? Java反射机制是在运行状态中,对于任意一个类,都...以上是关于Java反射机制的基本概念、用法和示例解析,希望能帮助你更好地理解和应用这一重要的Java特性。

    Java反射机制

    ### Java反射机制详解 #### 一、什么是Java的反射机制 Java反射机制是Java语言的一种重要特性,使得Java成为了一种动态性很强的语言。通过反射,可以在程序运行时获取类的信息,包括类名、父类、接口、字段、方法...

    JAVA反射机制的入门代码

    总的来说,"JAVA反射机制的入门代码"是初学者理解Java反射机制的好教材,通过它,你可以学习如何动态地操作Java类,提高代码的灵活性,并掌握处理`properties`文件的基础方法。在深入学习和实践中,你将进一步理解...

    利用java反射机制的建议计算器源码

    在这个“利用java反射机制的建议计算器源码”中,我们将深入探讨如何使用反射来构建一个可扩展的计算器,帮助新手更好地理解这一概念。 首先,让我们解释什么是反射。在Java中,反射机制允许我们获取类的信息(如...

    一个例子让你了解Java反射机制

    Java反射机制是Java编程语言中的一个重要特性,它允许运行中的Java程序对自身进行检查并且可以直接操作程序的内部属性。在Java中,反射机制的核心类集中在java.lang.reflect包下,包括Class、Constructor、Method和...

    Java 反射机制 代码的实例

    Java反射机制是Java编程语言中的一个强大特性,...通过学习和实践Java反射机制,你可以更深入地理解Java的运行机制,并在需要动态性、灵活性的场景中发挥其强大的功能。不过,使用反射时也应注意潜在的风险和性能影响。

    Java反射机制学习(二)

    在"Java反射机制学习(二)"这篇博文中,作者可能详细解释了以上这些概念,并通过`BaseTest.java`和`Student.java`这两个示例文件进行了实例演示。`BaseTest.java`可能包含了一组基础的反射操作,而`Student.java`...

    Java反射机制经典案例

    Java反射机制是Java编程语言中的一个强大特性,它允许程序在运行时检查和操作类、接口、字段和...通过阅读和学习提供的"Java反射机制经典案例"文档,你可以深入理解这些概念,并学会如何在实际项目中有效地应用反射。

    Java中的反射机制

    Java反射机制允许运行中的程序检查自身,并能直接操作程序的内部属性。这是其他许多编程语言(如Pascal、C或C++)不具备的能力。 **1.1 Reflection的工作机制** 为了展示反射如何工作,我们来看一个简单的例子: ...

    java反射机制

    ### Java反射机制知识点总结 #### 一、Java反射机制简介 Java反射机制是Java语言提供的一种强大特性,它使得程序可以在运行时动态地获取类的信息并直接操作对象的内部属性和方法。这种能力使得Java具备了一种动态...

    实战java反射机制-让你迅速认识java强大的反射机制

    Java反射机制是Java编程语言中的一个强大特性,它允许程序在运行时检查和操作类、接口、字段和方法的信息,甚至动态地创建对象并调用其方法。通过反射,开发者可以实现高度灵活和动态的代码,这对于框架开发、元编程...

    Java反射机制的详细讲解及实例,有助于java深度开发

    Java反射机制是Java编程语言中的一个强大特性,它允许程序在运行时检查和操作类、接口、字段和方法等对象。这一机制对于理解和利用Java的动态性至关重要,尤其是在进行复杂系统设计、框架开发以及元数据驱动的应用中...

    java 反射机制

    ### Java反射机制深入理解 #### 一、反射机制概述 Java反射机制是一种强大的工具,它允许程序在运行时检查和操作任何类、方法、构造函数和字段等元素。这种能力对于构建灵活的应用程序和框架非常有用,特别是那些...

    JAVA反射机制

    ### JAVA反射机制详解 #### 一、JAVA反射机制概述 **反射**是在1982年由Smith首次提出的概念,指的是程序有能力访问、检测并修改其自身的状态或行为。这一概念一经提出,便迅速引起了计算机科学领域的关注,并在多...

Global site tag (gtag.js) - Google Analytics