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

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()深入探讨 代码演示样例

    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,PHP,Java的数据库连接代码大全(带演示代码)

    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之反射(部分文档摘过来方便以后查看)

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

随机推荐

  1. sphinx全文检索引擎

    今天刚刚学习了一下,就直接分享上去,有些还没有接触,如果有问题请指正,谢谢 sphinx是什么? Sphinx是一个全文检索引擎.主要为其他应用提供高速.低空间占用.高结果 相关度的全文搜索功能. S ...

  2. linux重要的守护进程

    重要的守护进程 守护进程(Daemon)通常会随系统启动时激活并随系统关闭时停止,一直在系统后台中默默为用户提供服务: 守护进程名称 用处 crond 计划任务 dhcpd 动态IP地址分配服务(DH ...

  3. 【微信小程序】认识微信小程序

    目前微信小程序已经支持个人版了 罗列一下微信开发的一些资料和工具 (如果你还不了解微信小程序如何操作请点击  新手教程 )里面罗列了 开发者工具 如何使用 和 微信的基本操作 很详细 一.微信开发者工 ...

  4. uoj #58 【WC2013】糖果公园

    题面:http://uoj.ac/problem/58 正解:树上带修改莫队. 首先Orz vfk大神,树上莫队的套路还是很厉害的..http://vfleaking.blog.163.com/blo ...

  5. 子集构造法实现NFA的确定化

    功能: 采用子集构造算法实现NFA的确定化 输入:读取NFA的文件(文件名test.txt),  文件格式: 第一列表示状态名,第二列和第三列分别表示输入字符a和b到达的状态 输出:确定化后的DFA( ...

  6. DirectFB、Layer、Window、Surface之间关系

    层(Layers) 表示一块儿独立的图像缓冲区.大多数的嵌入式设备都有多个层.他们由硬件使用合适的alpha值来blending,然后显示. 表面 (Surface) 用来保存像素数据的保留内存区域. ...

  7. 32位机器的LowMemory

        今天在和供应商交流的过程中,被严重鄙视了,竟然认为我连"LowMemory"都没有听说过.感觉很郁闷,好歹我也搞过一段时间memory Management,怎么可能连Lo ...

  8. Android Material Design--TextInputLayout

    TextInputLayout 1. 简介 官网开篇: Layout which wraps an EditText (or descendant) to show a floating label ...

  9. Ajax与Pjax请求在服务端是如何识别的

    我在后台处理ajax和一般的网页请求时,一般是需要额外加个参数进行区分的.比如使用get参数的is_ajax=1,后台判断有is_ajax=1成立时,表明该请求是ajax请求,遂可区分处理.我正在使用 ...

  10. Docker - 访问仓库

    仓库与注册服务器 仓库(Repository)集中存放镜像的项目或目录. 注册服务器(Registry)管理仓库的服务器,服务器上可以有多个仓库,每个仓库有多个镜像. 例如:在仓库地址docker.i ...