Java之反射代码演示说明

时间:2022-09-04 10:19:06

还不存在的类–即我们需要使用反射来使用的类

Person类:

package com.qf.demo4;

public class Person {

    private String name;
public int age;
static int weight;
int male;
protected int num; public Person(String name, int age, int weight) {
this.name = name;
this.age = age;
this.weight = weight;
System.out.println("有参数的构造方法");
} public Person() {
System.out.println("无参数的构造方法");
} public void eat() {
System.out.println("吃");
} public void drink(String type) {
System.out.println("喝" + type);
} public String sleep() {
System.out.println("睡");
return "呵呵";
} private void play() {
System.out.println("玩");
} public static void hehe() {
System.out.println("heheheheh");
} @Override
public String toString() {
return "Person [name=" + name + ", age=" + age + ",weight = "+weight+"]";
}
}

演示代码:


Test1:创建Class对象

package com.qf.demo4;

import com.qf.demo.Person;
/**
* 每一个类只有一个class 对象
* com.qf.demo.Person 包名+类名 全限定名
* @author Administrator
*
*/
public class Test { public static void main(String[] args) {
// 创建Class 对象
// 第一种方式:类.class
Class class1 = Person.class;
System.out.println(class1.hashCode());
// 第二种方式:创建类的对象;然后--对象.getClass()
Person person = new Person();
Class class2 = person.getClass();
System.out.println(class2.hashCode()); // 第三种方式:使用forname方法,参数为相对于本工程的地址
try {
Class class3 = Class.forName("com.qf.demo.Person");
System.out.println(class3.hashCode());
} catch (ClassNotFoundException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
}
}

Test2:创建Constructor对象,并创建Person类(还没有的类)对象

package com.qf.demo4;

import java.lang.reflect.Constructor;
import java.lang.reflect.InvocationTargetException; public class Test2 { public static void main(String[] args) { try {
Class class1 = Class.forName("com.qf.demo4.Person");
Constructor[] constructors = class1.getConstructors();
for (Constructor constructor : constructors) {
System.out.println(constructor);
} // 1 通过构造方法创建 Perosn对象
Constructor constructor = class1.getConstructor(null);// 得到无参的构造方法
Person person = (Person) constructor.newInstance(null);
System.out.println(person); // 2 利用有参数的构造方法创建对象
Constructor constructor2 = class1.getConstructor(String.class,int.class,int.class);
Person person2 = (Person) constructor2.newInstance("张三",5,9);
System.out.println(person2);
} catch (ClassNotFoundException e) {
// TODO Auto-generated catch block
e.printStackTrace();
} catch (NoSuchMethodException e) {
// TODO Auto-generated catch block
e.printStackTrace();
} catch (SecurityException e) {
// TODO Auto-generated catch block
e.printStackTrace();
} catch (InstantiationException e) {
// TODO Auto-generated catch block
e.printStackTrace();
} catch (IllegalAccessException e) {
// TODO Auto-generated catch block
e.printStackTrace();
} catch (IllegalArgumentException e) {
// TODO Auto-generated catch block
e.printStackTrace();
} catch (InvocationTargetException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
}
}

Test3:获取方法,以及调用方法

package com.qf.demo4;

import java.lang.reflect.Constructor;
import java.lang.reflect.InvocationTargetException;
import java.lang.reflect.Method; public class Test3 { public static void main(String[] args) {
try {
Class class1 = Class.forName("com.qf.demo4.Person");
// 得到构造方法
Constructor constructor = class1.getConstructor(null);
Object object = constructor.newInstance(null); Method[] methods = class1.getMethods();// 得到本类和父类的非私有的方法 Method[] methods2 = class1.getDeclaredMethods();// 得到本类中声明的所有的方法(包括私有) // 得到 无参 无返回值的 方法并且调用
Method method = class1.getMethod("eat", null);
// 调用方法的对象 实际参数
method.invoke(object, null);// 是哪个方法被调用 // 调用 有参数 无返回值的方法
Method method2 = class1.getMethod("drink", String.class);
method2.invoke(object, "水"); // 有返回值的
Method method3 = class1.getMethod("sleep", null);
Object object2 = method3.invoke(object, null);// invoke方法的返回值就是调用的方法的返回值
System.out.println(object2); // 得到静态的方法
Method method4 = class1.getMethod("hehe", null);
method4.invoke(null, null);// 静态方法不需要传递对象 直接写null // 私有的 私有的方法 必须用 getDeclaredMethod 才能得到
Method method5 = class1.getDeclaredMethod("play", null);
method5.setAccessible(true);// 私有方法默认没有权限调用,必须单独设定调用权限
method5.invoke(object, null); } catch (ClassNotFoundException e) {
// TODO Auto-generated catch block
e.printStackTrace();
} catch (NoSuchMethodException e) {
// TODO Auto-generated catch block
e.printStackTrace();
} catch (SecurityException e) {
// TODO Auto-generated catch block
e.printStackTrace();
} catch (InstantiationException e) {
// TODO Auto-generated catch block
e.printStackTrace();
} catch (IllegalAccessException e) {
// TODO Auto-generated catch block
e.printStackTrace();
} catch (IllegalArgumentException e) {
// TODO Auto-generated catch block
e.printStackTrace();
} catch (InvocationTargetException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
}
}

反射定义:http://blog.csdn.net/baidu_37107022/article/details/71234940

Java之反射代码演示说明的更多相关文章

  1. 如何利用缓存机制实现JAVA类反射性能提升30倍

    一次性能提高30倍的JAVA类反射性能优化实践 文章来源:宜信技术学院 & 宜信支付结算团队技术分享第4期-支付结算部支付研发团队高级工程师陶红<JAVA类反射技术&优化> ...

  2. java 覆盖hashCode&lpar;&rpar;深入探讨 代码演示样例

    java 翻盖hashCode()深入探讨 代码演示样例 package org.rui.collection2.hashcode; /** * 覆盖hashcode * 设计HashCode时最重要 ...

  3. java 状态模式 解说演示样例代码

    package org.rui.pattern; import junit.framework.*; /** * 为了使同一个方法调用能够产生不同的行为,State 模式在代理(surrogate)的 ...

  4. java注意事项演示 地图产生表 演示样本 来自thinking in java 4 20代码的章

    java注意事项演示 地图产生表 演示样本  来自thinking in java 4 20代码的章 thinking in java 4免费下载:http://download.csdn.net/d ...

  5. DotNet&comma;PHP&comma;Java的数据库连接代码大全&lpar;带演示代码&rpar;

    C#数据库连接字符串 Web.config文件 <connectionStrings> <!--SQLServer数据库连接--> <add name="con ...

  6. Java用代码演示String类中的以下方法的用法

    用代码演示String类中的以下方法的用法 (1)boolean isEmpty(): 判断字符串是不是空串,如果是空的就返回true (2)char charAt(int index): 返回索引上 ...

  7. Java高新技术 反射机制

     Java高新技术 反射机制 知识概要:                   (1)反射的基石 (2)反射 (3)Constructor类 (4)Field类 (5)Method类 (6)用反射方 ...

  8. Java基础-反射(reflect)技术详解

    Java基础-反射(reflect)技术详解 作者:尹正杰 版权声明:原创作品,谢绝转载!否则将追究法律责任. 一.类加载器 1>.JVM 类加载机制  如下图所示,JVM类加载机制分为五个部分 ...

  9. Java之反射&lpar;部分文档摘过来方便以后查看&rpar;

    第1章 类加载器 1.1 类的加载 当程序要使用某个类时,如果该类还未被加载到内存中,则系统会通过加载,连接,初始化三步来实现对这个类进行初始化. l 加载 就是指将class文件读入内存,并为之创建 ...

随机推荐

  1. weibform中Application、ViewState对象和分页

    Application: 全局公共变量组 存放位置:服务器 特点:所有访问用户都是访问同一个变量,但只要服务器不停机,变量一直存在于服务器的内存中,不要使用循环大量的创建Application对象,可 ...

  2. BMP文件格式

  3. JavaScript的学习1

    1.什么是JavaScript? JavaScirpt 它是由网景公司开发的一款基本浏览器.基于面向对象.事件驱动式的网页脚本语言!它的主要应用场景是表单验证.网页特效.一些简单的网页游戏.与服务器进 ...

  4. java基础 数组14

    已知2个一维数组:a[]={3,4,5,6,7},b[]={1,2,3,4,5,6,7}:把数组a与数组b 对应的元素乘积再赋值给数组b,如:b[2]=a[2]*b[2]:最后输出数组b的元素.

  5. JavaEE PO VO BO DTO POJO DAO 整理总结

    佩服能将复杂难懂的技术,抽象成简单易懂事物的人. 厌恶将简单易懂的技术,添加一堆专业术语将别人弄的头晕目眩的人. PO VO BO DTO POJO DAO 总体一览: 1.DAO[data acce ...

  6. Unity3D的LightProbe动态光探头用法介绍

    原地址:http://liweizhaolili.blog.163.com/blog/static/16230744201371721511106/ 之前曾经介绍过Unity3D的LightMappi ...

  7. noproguard&period;classes-with-local&period;dex

    make: *** [out/target/common/obj/JAVA_LIBRARIES/framework_intermediates/noproguard.classes-with-loca ...

  8. MySQL 关闭子表的外键约束检察

    准备: 定义一个教师表.一个学生表:在学生表中引用教师表ID create table teachers(teacherID int not null auto_increment primary k ...

  9. SRM 582 Div II Level Three: ColorTheCells&comma; Brute Force 算法

    题目来源:http://community.topcoder.com/stat?c=problem_statement&pm=12581 Burte Force 算法,求解了所有了情况,注意  ...

  10. JS 正则表达式否定匹配(正向前瞻)

    引言:JS 正则表达式是 JS 学习过程中的一大难点,繁杂的匹配模式足以让人头大,不过其复杂性和其学习难度也赋予了它强大的功能.文章从 JS 正则表达式的正向前瞻说起,实现否定匹配的案例.本文适合有一 ...