`

java中的反射

 
阅读更多

      反射的概念是由Smith在1982年首次提出的,主要是指程序可以访问、检测和修改它本身状态或行为的一种能力。

      在java中可以通过反射获取一个类的所有信息。它使您能够创建灵活的代码,这些代码可以在运行时装配,无需在组件之间进行源代表链接。反射允许我们在编写与执行时,使我们的程序代码能够接入装载到JVM中的类的内部信息,而不是源代码中选定的类协作的代码。这使反射成为构建灵活的应用的主要工具。但需注意的是:如果使用不当,反射的成本很高。

JAVA的反射机制:

java反射机制是在运行状态中,对于任意一个雷类,都能够知道这个类的所有属性和方法;对于任意一个对象,都能够调用它的任意方法和属性;这种动态获取信息的以及动态调用对象的方法的功能称呼为java语言的反射机制。

一、反射机制的作用:

        反编译:.class-->.java

         通过反射机制访问java对象的属性,方法,构造方法等;

二、Java反射的功能

1)可以判断运行时对象所属的类

  2)可以判断运行时对象所具有的成员变量和方法

  3)通过反射甚至可以调用到private的方法

  4)生成动态代理

三、实现Java反射的类

1)Class:它表示正在运行的Java应用程序中的类和接口

2)Field:提供有关类或接口的属性信息,以及对它的动态访问权限

3)Constructor:提供关于类的单个构造方法的信息以及对它的访问权限

4)Method:提供关于类或接口中某个方法信息

  注意:Class类是Java反射中最重要的一个功能类,所有获取对象的信息(包括:方法/属性/构造方法/访问权限)都需要它来实现

四、编写java的反射程序,首先必须获取一个类的Class对象;

Class c1 = Test.class;
Class c2 = Class.forName(“类全名”);
Class c3 = new Test().getClass();

 五、然后分别调用Class对象中的方法来获取一个类的属性/方法/构造方法的结构如下代码;

public class TestReflection implements Serializable{
	private String username="张三";
	private String password="123456";
	private int age=20;
	private int[] score;
	
	public String getUsername() {
		return username;
	}

	public String getPassword() {
		return password;
	}
	public void setUserName(String username) {
		this.username = username;
	}

	private void setPassWord(String password) {
		this.password = password;
	}

	public static void test01() throws ClassNotFoundException {
		Class c1 = TestReflection.class;
		//Class c2 = Class.forName("com.zrrd.day25_2.TestReflection");
		// 获取指定的包名
		String package01 = c1.getPackage().getName();
		//String package02 = c2.getPackage().getName();
		System.out.println("--------------------------------------------------------");
		System.out.println("包名 = " + package01);
		//System.out.println("package02 = " + package02);
		// 获取类的修饰符
		int mod = c1.getModifiers();
		String modifier = Modifier.toString(mod);
		System.out.println("访问权限 = " + modifier);
		// 获取指定类的完全限定名
		String className = c1.getName();
		System.out.println("全类名 = " + className);
		// 获取指定类的父类
		Class superClazz = c1.getSuperclass();
		String superClazzName = superClazz.getName();
		System.out.println("父类名 = " + superClazzName);
		// 获取实现的接口
		Class[] interfaces = c1.getInterfaces();
		for (Class t : interfaces) {
			System.out.println("接口名 = " + t.getName());
		}
		// 获取指定类的成员变量
		Field[] fields = c1.getDeclaredFields();
		System.out.println("--------------------------------------------------------");
		System.out.println(c1+"类共有:"+fields.length+"个属性,如下:");
	   for (Field field : fields) {
		modifier = Modifier.toString(field.getModifiers()); // 获取每个字段的访问修饰符
			Class type = field.getType(); // 获取字段的数据类型所对应的Class对象
			String name = field.getName(); // 获取字段名
			if (type.isArray()) { // 如果是数组类型则需要特别处理
				String arrType = type.getComponentType().getName() + "[]";
				System.out.println("" + modifier + " " + arrType + " " + name + ";");
			} else {
				System.out.println("" + modifier + " " + type + " " + name + ";");
			}
		}
		
		// 获取类的构造方法
		Constructor[] constructors = c1.getDeclaredConstructors();
		System.out.println("--------------------------------------------------------");
		System.out.println(c1+"类共有:"+constructors.length+"个构造方法,如下:");
		for (Constructor constructor : constructors) {
			String name = constructor.getName(); // 构造方法名
			modifier = Modifier.toString(constructor.getModifiers()); // 获取访问修饰符
			System.out.print("" + modifier + " " + name + "(");
			Class[] paramTypes = constructor.getParameterTypes(); // 获取构造方法中的参数
			for (int i = 0; i < paramTypes.length; i++) {
				if (i > 0) {
					System.out.print(",");
				}
				if (paramTypes[i].isArray()) {
					System.out.println(paramTypes[i].getComponentType()
							.getName() + "[]");
				} else {
					System.out.print(paramTypes[i].getName());
				}
			}
			System.out.println(");");
		}
		// 获取成员方法
		Method[] methods = c1.getDeclaredMethods();
		System.out.println("--------------------------------------------------------");
		System.out.println(c1+"类共有:"+methods.length+"个方法,如下:");
		for (Method method : methods) {
			modifier = Modifier.toString(method.getModifiers());
			Class returnType = method.getReturnType(); // 获取方法的返回类型
			if (returnType.isArray()) {
				String arrType = returnType.getComponentType().getName() + "[]";
				System.out.print("" + modifier + " " + arrType + " "
						+ method.getName() + "(");
			} else {
				System.out.print("" + modifier + " " + returnType.getName()
						+ " " + method.getName() + "(");
			}
			Class[] paramTypes = method.getParameterTypes();
			for (int i = 0; i < paramTypes.length; i++) {
				if (i > 0) {
					System.out.print(",");
				}
				if (paramTypes[i].isArray()) {
					System.out.print(paramTypes[i].getComponentType()
							.getName() + "[]");
				} else {
					System.out.print(paramTypes[i].getName());
				}
			}
			System.out.println(");");			
		}
		System.out.println("--------------------------------------------------------");
	}

	public static void test02() throws InstantiationException,
			IllegalAccessException, SecurityException, NoSuchMethodException,
			IllegalArgumentException, InvocationTargetException {
		// 反射调用方法,可以通过Method类的invoke方法实现动态方法的调用
		// public Object invoke(Object obj, Object... args)
		// 第一个参数代表对象
		// 第二个参数代表执行方法上的参数
		// 若反射要调用类的某个私有方法,可以在这个私有方法对应的Mehtod对象上先调用setAccessible(true)
		//TestReflection tf=new TestReflection();
		Class c1 = TestReflection.class;
		TestReflection t1 = (TestReflection) c1.newInstance(); // 利用反射来创建类的对象
		System.out.println("username == " + t1.username);
		System.out.println("password == " + t1.password);
		//获取setUserName方法
		Method method = c1.getDeclaredMethod("setUserName", String.class);
		//动态调用setUserName方法
		method.invoke(t1, "Java反射的学习");
		Method method1 = c1.getDeclaredMethod("getUsername", null);
		String ss=(String)method1.invoke(t1, null);
		//System.out.println("username == " + t1.username);
		System.out.println("username == " + ss);
		method = c1.getDeclaredMethod("setPassWord", String.class);
		method.setAccessible(true);
		method.invoke(t1, "反射执行某个Private修饰的方法");
		System.out.println("password == " + t1.password);
	}

	public static void main(String[] args) throws ClassNotFoundException,
			SecurityException, IllegalArgumentException,
			InstantiationException, IllegalAccessException,
			NoSuchMethodException, InvocationTargetException {
//		    test01();
		    test02();
	}
}

 

 

 

分享到:
评论

相关推荐

    java中反射的概念

    总的来说,Java反射机制是面向对象编程的一个重要补充,它扩展了Java程序的动态性,允许程序员在运行时访问和操作类的内部结构,增强了代码的灵活性。理解和熟练掌握反射技术,对于提升Java编程能力,尤其是处理复杂...

    java中反射知识总结

    2. **类对象** - 在Java中,每个类都有一个对应的Class对象,它是Java反射的入口。我们可以通过Class对象来实例化对象、获取类的构造器、方法和字段信息。例如,`Class&lt;?&gt; clazz = Class.forName("全限定类名");` 这...

    Java中的反射

    ### Java中的反射 #### 一、反射的基本概念 反射(Reflection)的概念最早由Smith于1982年提出,指的是程序能够访问、检测并修改其自身的行为或状态的能力。这种能力使得程序可以根据自身的运行状态和结果来调整或...

    java例子 java反射

    在Java反射中,访问类的字段和方法也十分灵活。`getFields()`返回所有public字段,`getField()`获取指定名称的public字段。对于私有或其他访问修饰符的字段,可以使用`getDeclaredFields()`和`getDeclaredField()`。...

    java习题-反射-chap15.pdf

    Chp15 反射Key Point ●Class 对象及其基本操作●Method 对象以及invoke 方法●标注练习 1. (类对象)要获得类对象,有三种不同的方式,分别为_____________________、___________________、_____________________...

    Java方法反射调用demo

    Java反射是Java编程语言中的一个强大特性,它允许在运行时检查类、接口、字段和方法的信息,并且能够在运行时动态地创建对象和调用方法。这个特性使得Java具有了高度的灵活性,常用于框架开发、插件系统、元编程等...

    java反射 java反射 java反射java反射

    Java反射是Java编程语言中的一个重要特性,它允许程序在运行时动态地获取类的信息并操作类的对象。在Java中,反射机制提供了强大的能力,包括在运行时检查类的结构、创建对象实例、调用方法以及访问和修改字段值。...

    java之反射优化(缓存思路)源码

    在Java编程中,反射(Reflection)是一个强大的工具,它允许我们在运行时检查和操作类、接口、字段和方法。然而,反射操作通常比直接的Java代码执行慢,因为它涉及到动态类型检查和方法调用。因此,为了提高性能,...

    Java中的反射机制

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

    java面试题--反射机制

    `Class`类在Java反射机制中扮演着核心角色,它是所有Java类的运行时表示。`Class`对象可以由以下几种方式获取: 1. **通过类的`Class`属性获取**:如`String.class`。 2. **通过对象的`getClass()`方法获取**:如`...

    反射实例-JAVA反射机制

    在Java反射中,针对类的不同组成部分(构造函数、字段和方法),`java.lang.Class`类提供了多种反射调用方式来获取信息。以下是几种常用的反射调用: - **获取构造函数**:`Constructor getConstructor(Class[] ...

    java 通过反射获取枚举类,及枚举类的值,枚举类枚举实例名

    在Java编程语言中,反射(Reflection)是一种强大的工具,它允许程序在运行时检查和操作类、接口、字段和方法等对象。枚举(Enumeration)是Java中的一个特殊类类型,用于定义一组常量。本项目"test-enum-demo-...

    java反射与EJBjava反射与EJBjava反射与EJBjava反射与EJBjava反射与EJB

    Java反射和EJB(Enterprise JavaBeans)是Java开发中的两个重要概念,它们分别涉及程序运行时的动态性以及企业级应用的组件模型。 Java反射机制是Java语言提供的一种能力,允许程序在运行时检查和操作类、接口、...

    java反射,获取所有属性、方法以及List集合类

    Java反射是Java编程语言中的一个强大工具,它允许运行中的Java程序对自身进行检查并且可以直接操作程序的内部属性。在Java中,反射主要用于在运行时分析类和对象,包括访问私有成员、调用私有方法、创建对象、获取类...

    Java反射机制总结

    ### Java反射机制总结 #### 反射的概念与起源 反射的概念最早由Smith于1982年提出,指的是程序能够访问、检测并修改其自身状态或行为的能力。这一概念的提出迅速引起了计算机科学领域的广泛关注,并在之后的研究中...

    Java 1.5 反射机制

    反射机制的核心是`Class`类,它代表了Java中的每一个类型。通过`Class.forName()`方法,我们可以根据类名获取`Class`对象。一旦有了`Class`对象,我们就可以实例化对象,调用构造器,以及获取类的信息,如类名、...

    JAVA反射机制的入门代码

    Java反射机制是Java编程语言中的一个强大特性,它允许运行中的Java程序对自身进行检查并且可以直接操作程序的内部属性。这个特性使得Java具有了高度的灵活性和动态性,尤其是在处理元数据、创建对象、调用私有方法...

    java反射机制.zip

    java反射机制java反射机制.zipjava反射机制.zipjava反射机制.zipjava反射机制.zipjava反射机制.zipjava反射机制.zipjava反射机制.zipjava反射机制.zipjava反射机制.zipjava反射机制.zipjava反射机制.zipjava反射机制...

    java 反射得到某个方法

    在本文中,我们将深入探讨如何使用Java反射来获取并执行某个特定的方法。 首先,我们需要了解Java反射的基本概念。`java.lang.Class`类是反射的核心,它代表了Java中的每一个类。我们可以通过以下方式获取到一个...

    Java反射经典实例

    Java反射是Java编程语言中的一个强大特性,它允许运行时的程序访问并操作类、接口、字段和方法等信息,即使这些信息在编译时并未明确知晓。在Java中,反射通常通过`java.lang.Class`类和相关的API来实现。本实例将...

Global site tag (gtag.js) - Google Analytics