列举java语言中反射的常用方法及实例代码

Java反射机制

一、什么是反射机制 

简单的来说,反射机制指的是程序在运行时能够获取自身的信息。在java中,只要给定类的名字,
    那么就可以通过反射机制来获得类的所有信息。

二、哪里用到反射机制 

有些时候,我们用过一些知识,但是并不知道它的专业术语是什么,在刚刚学jdbc时用过一行代码,
    Class.forName("com.mysql.jdbc.Driver.class").newInstance();但是那时候只知道那行代码是生成
    驱动对象实例,并不知道它的具体含义。听了反射机制这节课后,才知道,原来这就是反射,现在很多开

框架都用到反射机制,hibernate、struts都是用反射机制实现的。

三、反射机制的优点与缺点 

为什么要用反射机制?直接创建对象不就可以了吗,这就涉及到了动态与静态的概念,

静态编译:在编译时确定类型,绑定对象,即通过。

动态编译:运行时确定类型,绑定对象。动态编译最大限度发挥了java的灵活性,体现了多
    态的应用,有以降低类之间的藕合性。

一句话,反射机制的优点就是可以实现动态创建对象和编译,体现出很大的灵活性,特别是在J2EE的开发中它的灵活性就表现的十分明显。比如,一个大型的软件,不可能一次就把把它设计的很完美,当这个程序编译后,发布了,当发现需要更新某些功能时,我们不可能要用户把以前的卸载,再重新安装新的版本,假如这样的话,这个软件肯定是没有多少人用的。采用静态的话,需要把整个程序重新编译一次才可以实现功能的更新,而采用反射机制的话,它就可以不用卸载,只需要在运行时才动态的创建和编译,就可以实现该功能。

它的缺点是对性能有影响。使用反射基本上是一种解释操作,我们可以告诉JVM,我们希望做什么并且它
    满足我们的要求。这类操作总是慢于只直接执行相同的操作。

列举java语言中反射的常用方法

package review;/*12:43 2019/7/21*/
import model.AnotherClass;
import model.OneClassMore;
import model.SomeClass;
import java.lang.reflect.Constructor;
import java.lang.reflect.Field;
import java.lang.reflect.InvocationTargetException;
import java.lang.reflect.Method;
/**
 * 这个类列举了java语言中关于反射机制的常用的一些方法
 * @author zhangxingshuo
 */
public class AboutReflection {
  public static void main(String[] args) throws Exception {
  }
  /*获得Class对象的3种方式*/
  private static Class<?> getClazz0(String className) throws ClassNotFoundException {
    Class clazz=Class.forName(className);
    return clazz;
  }
  private static Class<?> getClazz1(Object object) {
    Class clazz=object.getClass();
    return clazz;
  }
  private static Class<?> getClazz2() {
    Class clazz=model.SomeClass.class;
    return clazz;
  }
  /*经常使用的Class对象的3个方法*/
  private static String useClazz0(Class clazz) {
    String fullyQualifiedName=clazz.getName();
    return fullyQualifiedName;
  }
  private static String useClazz1(Class clazz) {
    String className=clazz.getSimpleName();
    return className;
  }                          //ex:private      //ex:abstract
  private static Object useClazz2(Class clazz) throws IllegalAccessException, InstantiationException {
    Object object=clazz.newInstance();
    return object;
  }
  /*获得Constructor对象的3个方法*/
  private static Constructor<?>[] getConstructorObject0(Class clazz) {
    Constructor<?>[] constructors=clazz.getConstructors();
    return constructors;
  }
  private static Constructor<?>[] getConstructorObject1(Class clazz) {
    Constructor<?>[] constructors=clazz.getDeclaredConstructors();
    return constructors;
  }
  private static Constructor<?> getConstructorObject2(Class clazz) throws NoSuchMethodException {
    Constructor<?> constructor=clazz.getConstructor(SomeClass.class, AnotherClass.class, OneClassMore.class);
    return constructor;
  }
  private static Constructor<?> getConstructorObject3(Class clazz) throws NoSuchMethodException {
    Constructor<?> constructor=clazz.getDeclaredConstructor(SomeClass.class, AnotherClass.class, OneClassMore.class);
    return constructor;
  }
  /*经常使用的Constructor对象的2个方法*/
  private static Object useConstructorObject0(Constructor<?> constructor) throws IllegalAccessException, InvocationTargetException, InstantiationException {
                //under here,if the variable override==true,jvm willl not check the accessible modifier
    Object object=constructor.newInstance(new SomeClass(),new AnotherClass(),new OneClassMore());
    return object;
  }
  private static void useConstructorObject1(Constructor<?> constructor) {
                //under here changing "override" variable's value who is defined in AccessibleObject,the "super and super" Class of Constructor
    constructor.setAccessible(true);
  }
  /*还有一些*/
  private static Class<?> useConstructorObject2(Constructor<?> constructor) {
    Class clazz=constructor.getDeclaringClass();
    return clazz;
  }
  private static int useConstructorObject3(Constructor<?> constructor) {
    int modifiers=constructor.getModifiers();
    return modifiers;
  }
  private static String useConstructorObject4(Constructor<?> constructor) {
       //constructor name is same as the class name
    String constructorName = constructor.getName();
                      //under here getDeclaringClass().getName();
    return constructorName;
  }
  /*获取Field对象的4个方法*/
  private static Field[] getFieldObject0(Class clazz){
    Field[] fields = clazz.getFields();
    return fields;
  }
  private static Field[] getFieldObject1(Class clazz){
    Field[] declaredFields = clazz.getDeclaredFields();
    return declaredFields;
  }
  private static Field getFieldObject2(Class clazz) throws NoSuchFieldException {
    Field field = clazz.getField("theFieldName");
    return field;
  }
  private static Field getField3(Class clazz) throws NoSuchFieldException {
    Field field = clazz.getDeclaredField("theFieldName");
    return field;
  }
  /*经常使用的Field对象的3个方法*/
  private static Object useFieldObject0(Field field,Object object) throws IllegalAccessException {
    Object fieldValue = field.get(object);
    return fieldValue;
  }
  private static void useFieldObject1(Field field,Object object) throws IllegalAccessException {
            //an object as the field value
    field.set(object,new Object());
  }
  private static void useFieldObject2(Field field){
             //same process
    field.setAccessible(true);
  }
  /*还有一些*/
  private static int useFieldObject3(Field field){
    int modifiers = field.getModifiers();
    return modifiers;
  }
  private static String useFieldObject4(Field field){
    String fieldName = field.getName();
    return fieldName;
  }
  /*获取Method对象的4个方法*/
  private static Method[] getMethodObject0(Class clazz){
    Method[] methods=clazz.getMethods();
    return methods;
  }
  private static Method[] getMethodObject1(Class clazz){
    Method[] methods=clazz.getDeclaredMethods();
    return methods;
  }
  private static Method getMethodObject2(Class clazz) throws NoSuchMethodException {
    Method method=clazz.getMethod("someMethodName",SomeClass.class,AnotherClass.class,OneClassMore.class);
    return method;
  }
  private static Method getMethodObject3(Class clazz) throws NoSuchMethodException {
    Method method=clazz.getDeclaredMethod("someMethodName",SomeClass.class,AnotherClass.class,OneClassMore.class);
    return method;
  }
  /*经常使用的Field对象的2个方法*/
  private static Object useMethodObject0(Method method,Object object) throws InvocationTargetException, IllegalAccessException {
    Object returnedobject=method.invoke(object,new SomeClass(),new AnotherClass(),new OneClassMore());
    return returnedobject;
  }
  private static void useMethodObject1(Method method){
    method.setAccessible(true);
  }
  /*还有一些*/
  private static int useMethodObject2(Method method){
    int modifiers = method.getModifiers();
    return modifiers;
  }
  private static String useMethodObject3(Method method){
    String methodName = method.getName();
    return methodName;
  }
  /*
  tips
  通过getMethods(),得到该类或接口独有的和继承自它的所有父类与接口的public方法组成的数组.
  通过getDeclaredMethods(),得到该类或接口独有的所有方法,(包括public和非public).
  */
  /*just as a empty template for convenience*/
  private static void m(){
  }
}

总结

以上所述是小编给大家介绍的列举java语言中反射的常用方法及实例代码,希望对大家有所帮助,如果大家有任何疑问欢迎给我留言,小编会及时回复大家的!

(0)

相关推荐

  • Java中反射动态代理接口的详解及实例

    Java语言中反射动态代理接口的解释与演示 Java在JDK1.3的时候引入了动态代理机制.可以运用在框架编程与平台编程时候捕获事件.审核数据.日志等功能实现,首先看一下设计模式的UML图解: 当你调用一个接口API时候,实际实现类继承该接口,调用时候经过proxy实现. 在Java中动态代理实现的两个关键接口类与class类分别如下: java.lang.reflect.Proxy java.lang.reflect.InvocationHandler 我们下面就通过InvocationHan

  • Java利用反射如何查找使用指定注解的类详解

    前言 最近有些空,想自己写个跟spring里的注解一样的注解来用,然后希望能找到使用了自己写了注解的类,下面来介绍一下实现方法 声明,下面代码是没看过spring源码写的,基本上都是网上找的博客,整理的 定义注解 Controller.java @Target({ElementType.TYPE}) @Retention(RetentionPolicy.RUNTIME) @Documented public @interface Controller { } RequestMapping.jav

  • Java反射如何有效的修改final属性值详解

    前言 以前写过一篇 Java 反射修改 final 属性值,本文将在这里重新温习一下Java反射如何有效的修改final属性值,下面话不多说了,来一起看看详细的介绍: 假设有个类 class Person { public final String name = "Mike"; } 这里声明 name 为非静态的属性只是为了说明反射修改 final 属性无关乎静态不静态,静态只是表现在它是一个类属性,在一个类加载器空间只会有一份拷贝,仅此而已. 创建一个通用方法进行反射修改属性值 pu

  • java反射遍历实体类属性和类型,并赋值和获取值的简单方法

    实例如下: import java.lang.reflect.Field; import java.lang.reflect.InvocationTargetException; import java.lang.reflect.Method; import java.util.Date; /** * 获取实体类型的属性名和类型 * @param model 为实体类 * @author kou 为传入参数 */ public class GetModelNameAndType { public

  • java反射获取和调用方法

    Class类中获取方法: public Method[] getMethods();//获取包括自身和继承(实现)过来的所有的public方法--Method不支持泛型<>,即后面不接<> public Method[] getDeclaredMethods();//获取自身所有的方法(private.public.protected,和访问权限无关),不包括继承的 在jdk1.8后可以直接获取私有属性的方法不需要设置权限 但是仅限于getDeclaredMethod方法 对于Me

  • Java通过PropertyDescriptor反射调用set和get方法

    本文实例为大家分享了PropertyDescriptor反射调用set和get方法,供大家参考,具体内容如下 第一段: package com.zhoushun; import java.lang.reflect.Method; import java.lang.reflect.Field; import java.beans.PropertyDescriptor; public class PropertyUtil { @SuppressWarnings("unchecked") p

  • 老生常谈Java反射机制(必看篇)

    什么是反射机制 反射是java语言的一个特性,它允程序在运行时(注意不是编译的时候)来进行自我检查并且对内部的成员进行操作.例如它允许一个java的类获取他所有的成员变量和方法并且显示出来.这个能特定我们不常看到,但是在其他的比如C或者C++语言中很不就存在这个特性.一个常见的例子是在JavaBean中,一些组件可以通过一个构造器来操作.这个构造器就是用的反射在动态加载的时候来获取的java中类的属性的. 主要的类 Class 类的实例表示正在运行的 Java 应用程序中的类和接口.Class没

  • java反射获取一个object属性值代码解析

    有些时候你明明知道这个object里面是什么,但是因为种种原因,你不能将它转化成一个对象,只是想单纯地提取出这个object里的一些东西,这个时候就需要用反射了. 假如你这个类是这样的: private class User { String userName; String userPassword; public String getUserName() { return userName; } public void setUserName(String userName) { this.

  • Java利用反射获取object的属性和值代码示例

    在看反射顺便做个笔记,目前知道的反射的Object都是要有对象的也就是实体Bean. referance:Java反射简易教程 import java.lang.reflect.Field; import java.util.ArrayList; import java.util.HashMap; import java.util.List; import java.util.Map; /** * 反射处理Bean,得到里面的属性值 * * @author liulinsen * */ publ

  • 列举java语言中反射的常用方法及实例代码

    Java反射机制 一.什么是反射机制  简单的来说,反射机制指的是程序在运行时能够获取自身的信息.在java中,只要给定类的名字,     那么就可以通过反射机制来获得类的所有信息. 二.哪里用到反射机制  有些时候,我们用过一些知识,但是并不知道它的专业术语是什么,在刚刚学jdbc时用过一行代码,     Class.forName("com.mysql.jdbc.Driver.class").newInstance();但是那时候只知道那行代码是生成     驱动对象实例,并不知道

  • Java语言中的自定义类加载器实例解析

    本文研究的主要是Java语言中的自定义类加载器实例解析的相关内容,具体如下. 自己写的类加载器 需要注意的是:如果想要对这个实例进行测试的话,首先需要在c盘建立一个c://myjava的目录.然后将相应的java文件放在这个目录中.并将产生的.clas文件放在c://myjava/com/lg.test目录下,否则是找不到的.这是要注意的.. class FileClassLoader : package com.lg.test; import java.io.ByteArrayOutputSt

  • Java语言描述MD5加密工具类实例代码

    编程中经常有用到MD5加密的情况,Java语言并没有像PHP一样提供原生的MD5加密字符串的函数,需要MD5加密的时候,往往需要自己写. 代码如下: import java.security.MessageDigest; public class MD5 { //公盐 private static final String PUBLIC_SALT = "demo" ; //十六进制下数字到字符的映射数组 private final static String[] hexDigits =

  • C语言中数据结构之链表归并排序实例代码

    C语言中数据结构之链表归并排序实例代码 问题 设有两个无头结点的单链表,头指针分别为ha,hb,链中有数据域data,链域next,两链表的数据都按递增排序存放,现要求将hb表归到ha表中,且归并后ha仍递增序,归并中ha表中已有的数据若hb中也有,则hb中的数据不归并到ha中,hb的链表在算法中不允许破坏. 源程序 #include <stdio.h> #include<stdlib.h> #define N1 6 /*链表La的长度*/ #define N2 6 /*链表Lb的

  • 枚举java语言中的修饰符组合的实例代码

    枚举java语言中的修饰符组合,代码如下所示: package model; /*22:37 2019/7/20*/ /* top class的修饰符组合 abstract final public * 2 * 2 warning: abstract final 冲突 最终,共有2*(2*2-1)=6种修饰符组合用于top class */ /* public abstract class PublicAbstractClass{} public final class PublicFinalC

  • Java语言中链表和双向链表

    链表是一种重要的数据结构,在程序设计中占有很重要的地位.C语言和C++语言中是用指针来实现链表结构的,由于Java语言不提供指针,所以有人认为在Java语言中不能实现链表,其实不然,Java语言比C和C++更容易实现链表结构.Java语言中的对象引用实际上是一个指针(本文中的指针均为概念上的意义,而非语言提供的数据类型),所以我们可以编写这样的类来实现链表中的结点. class Node { Object data; Node next;//指向下一个结点 } 将数据域定义成Object类是因为

  • 探讨Java语言中那些修饰符

    一.在java中提供的一些修饰符,这些修饰符可以修饰类.变量和方法,在java中常见的修饰符有:abstract(抽象的).static(静态的).public(公共的).protected(受保护的).private(私有的).synchronized(同步的).native(本地的).transient(暂时的).volatile(易失的).final(不可改变的) 二.修饰顶层类的修饰符包括abstract.public和final,而static.protected和private不能修

  • Java语言中&&与& ||与|的区别是什么

    1.运算符两边的变量为boolean变量时 先列出代码: public class Test { public static void main(String[] args) { boolean a = false; boolean b = true; if (a && b) { // do something System.out.println("a&&b"); } if (a & b) { // do something System.ou

  • Java语言中的内存泄露代码详解

    Java的一个重要特性就是通过垃圾收集器(GC)自动管理内存的回收,而不需要程序员自己来释放内存.理论上Java中所有不会再被利用的对象所占用的内存,都可以被GC回收,但是Java也存在内存泄露,但它的表现与C++不同. JAVA中的内存管理 要了解Java中的内存泄露,首先就得知道Java中的内存是如何管理的. 在Java程序中,我们通常使用new为对象分配内存,而这些内存空间都在堆(Heap)上. 下面看一个示例: public class Simple { public static vo

  • java语言中封装类代码示例

    在面向对象程序设计方法中,封装(Encapsulation)是指一种将抽象性函式接口的实现细节部分包装'隐藏起来的方法.数据被保护在内部,隐藏内部实现细节,对外提供接口与外部交互. 使用封装的步骤 将类的所有属性使用关键字private去修饰,把它们变成私有的,不允许外部类直接访问 生成或者提供公共的setter/getter方法去操作这些被隐藏起来的属性 在类自己的 setter/getter方法中加入逻辑控制,以确保数据访问的有效性和安全性实例 让我们来看一个java封装类的例子: /* 文

随机推荐