反射机制还可以调用类中的指定方法或指定属性,并且可以通过反射完成对数组的操作。

通过反射调用类中的方法

import java.lang.reflect.Method;

//=================================================
// File Name : InvokeChina_demo
//------------------------------------------------------------------------------
// Author : Common //主类
//Function : InvokeChina_demo;
public class InvokeChina_demo { public static void main(String[] args) {
// TODO 自动生成的方法存根
Class<?> c1 = null; //指定泛型
try{
c1 = Class.forName("Person_5"); //传入要实例化类的完整包.类名称
}catch(ClassNotFoundException e){
e.printStackTrace();
}
try{
Method met = c1.getMethod("sayChina"); //取得一个Method对象
met.invoke(c1.newInstance()); //使用invoke进行调用,必须传递对象实例
}catch(Exception e){
e.printStackTrace();
}
} }

可以向方法中传递两个参数

import java.lang.reflect.Method;

//=================================================
// File Name : InvokeChina_demo
//------------------------------------------------------------------------------
// Author : Common //主类
//Function : InvokeChina_demo;
public class InvokeChina_demo { public static void main(String[] args) {
// TODO 自动生成的方法存根
Class<?> c1 = null; //指定泛型
try{
c1 = Class.forName("Person_5"); //传入要实例化类的完整包.类名称
}catch(ClassNotFoundException e){
e.printStackTrace();
}
try{ Method met = c1.getMethod("sayHello",String.class,int.class); //此方法需要两个参数
String rv = null; //接收方法的返回值
rv = (String)met.invoke(c1.newInstance(),"李四",32); //使用invoke进行调用,必须传递对象实例
System.out.println(rv);
}catch(Exception e){
e.printStackTrace();
}
} }

调用setter和getter方法

import java.lang.reflect.Method;

//=================================================
// File Name : InvokeSetGet_demo
//------------------------------------------------------------------------------
// Author : Common //主类
//Function : InvokeSetGet_demo;
public class InvokeSetGet_demo { public static void main(String[] args) {
// TODO 自动生成的方法存根
Class<?> c1 = null; //指定泛型
Object obj = null; //声明一个对象
try{
c1 = Class.forName("Person_5"); //传入要实例化类的完整包.类名称
}catch(ClassNotFoundException e){
e.printStackTrace();
}
try{
obj = c1.newInstance(); //实例化操作对象
}catch(InstantiationException | IllegalAccessException e){
e.printStackTrace();
} setter(obj, "name", "张三", String.class);
setter(obj, "age", 25, int.class);
System.out.println("姓名:");
getter(obj, "name");
System.out.println("年龄:");
getter(obj, "age");
} public static void setter(Object obj,String att,Object value,Class<?> type){
try{
Method met = obj.getClass().getMethod("set"+initStr(att),type); //设置方法参数类型
met.invoke(obj, value); //调用方法
}catch(Exception e){
e.printStackTrace();
}
} public static void getter(Object obj,String att){
try{
Method met = obj.getClass().getMethod("get"+initStr(att));
System.out.println(met.invoke(obj)); //接收方法的返回值
}catch(Exception e){
e.printStackTrace();
}
} public static String initStr(String old){
String str = old.substring(0, 1).toUpperCase()+old.substring(1); //首字母大写
return str; } }

直接操作类中的属性

import java.lang.reflect.Field;

//=================================================
// File Name : InvokeField_demo
//------------------------------------------------------------------------------
// Author : Common //主类
//Function : InvokeField_demo;
public class InvokeField_demo { public static void main(String[] args) throws Exception {
// TODO 自动生成的方法存根
Class<?> c1 = null; //声明Class对象
Object obj = null; //声明一个对象 c1 =Class.forName("Person_5"); //实例化Class对象
obj = c1.newInstance(); //实例化对象 Field nameField = null; //表示name属性
Field ageField = null; //表示age属性
nameField = c1.getDeclaredField("name"); //取得name属性
ageField = c1.getDeclaredField("age"); //取得age属性 nameField.setAccessible(true); //将name属性设置成可被外部访问
nameField.set(obj, "张三"); //设置name属性内容
ageField.setAccessible(true); //将age属性设置成可被外部访问
ageField.set(obj, 33); //设置age属性内容 System.out.println("姓名:"+nameField.get(obj)); //通过get取得属性内容
System.out.println("年龄:"+ageField.get(obj));
} }

通过反射操作数组

import java.lang.reflect.Field;
import java.lang.reflect.Array; //=================================================
// File Name : InvokeField_demo
//------------------------------------------------------------------------------
// Author : Common //主类
//Function : InvokeField_demo;
public class InvokeField_demo { public static void main(String[] args) throws Exception {
// TODO 自动生成的方法存根 int temp[] = {1,2,3};
Class<?> c = temp.getClass().getComponentType(); //取得数组的Class对象 System.out.println("类型:"+c.getName()); //得到数组类型名称
System.out.println("长度:"+Array.getLength(temp)); //得到数组长度
System.out.println("第一个内容:"+Array.get(temp,0)); //得到第一个内容
Array.set(temp,0,6); //修改第一个内容
System.out.println("第一个内容:"+Array.get(temp,0)); //得到第一个内容
} }

Java反射机制<2>的更多相关文章

  1. 第28章 java反射机制

    java反射机制 1.类加载机制 1.1.jvm和类 运行Java程序:java 带有main方法的类名 之后java会启动jvm,并加载字节码(字节码就是一个类在内存空间的状态) 当调用java命令 ...

  2. Java反射机制

    Java反射机制 一:什么事反射机制 简单地说,就是程序运行时能够通过反射的到类的所有信息,只需要获得类名,方法名,属性名. 二:为什么要用反射:     静态编译:在编译时确定类型,绑定对象,即通过 ...

  3. java基础知识(十一)java反射机制(上)

    java.lang.Class类详解 java Class类详解 一.class类 Class类是java语言定义的特定类的实现,在java中每个类都有一个相应的Class对象,以便java程序运行时 ...

  4. java基础知识(十一)java反射机制(下)

    1.什么是反射机制? java反射机制是在运行状态中,对于任意一个类,都能够知道这个类的所有属性和方法,对于任意一个对象都能够调用他的属性和方法,这种动态获取属性和方法的功能称为java的反射机制. ...

  5. Java反射机制专题

    ·Java Reflection Reflection(反射)是被视为动态语言的关键,反射机制允许程序在执行期借助于Reflection API取得任何类的内部信息,并能直接操作任意对象的内部属性及方 ...

  6. java反射机制深入详解

    java反射机制深入详解  转自:http://www.cnblogs.com/hxsyl/archive/2013/03/23/2977593.html 一.概念 反射就是把Java的各种成分映射成 ...

  7. Java反射机制DOME

    Java反射机制 public class TestHibernate { @Test public void TestHb(){ try { Class cs = Class.forName(&qu ...

  8. 反射——Java反射机制

    反射概述 什么是反射? ①   反射的概念是由Smith在1982年首次提出的,主要指程序可以访问.检测和修改它本身状态或行为的一种能力. ②   JAVA反射机制是在运行状态中,对应任意一个类,都能 ...

  9. Java反射机制可以动态修改实例中final修饰的成员变量吗?

    问题:Java反射机制可以动态修改实例中final修饰的成员变量吗? 回答是分两种情况的. 1. 当final修饰的成员变量在定义的时候就初始化了值,那么java反射机制就已经不能动态修改它的值了. ...

  10. Java反射机制学习与研究

    Java反射机制:可以获取正在运行时的Java对象. 1.判断运行时对象对象所属的类. 2.判断运行时对象所具有的成员变量和方法. 3.还可以调用到private方法,改变private变量的值. S ...

随机推荐

  1. cxf和spring结合,发布restFull风格的服务

    rest(Representational State Transfer):表现层状态转化,它是一种风格,用于资源定位,例如:http://ip:port/user/student/001 和资源操作 ...

  2. Android studio配置Git

    Android studio配置Git 1.下载window 版git并安装:下载地址 2.Android Studio设置git插件:File->Setting->Version Con ...

  3. 【CodeVS 1198】【NOIP 2012】国王游戏

    http://codevs.cn/problem/1198/ 推导一翻,排好序后,直接上高精度. #include<cstdio> #include<cstring> #inc ...

  4. HttpHelper类

    using System;using System.Collections.Generic;using System.Text;using System.Net;using System.IO;usi ...

  5. 100114D

    这道题用暴力水过了,蒟蒻是这么想的:枚举两个端点,找最小值,因为shift只能用一次,但是这样10^9*2.5要t,所以减掉只有一个黑点的情况,然后复杂度变为10^9*0.6 #include< ...

  6. C#-WinForm-进程、线程

    进程:一个程序就是一个进程,也有可能一个程序需要多个进程来支持的情况,比如QQ 点击按钮打开记事本,静态方法 public partial class Form3 : Form { public Fo ...

  7. 【POJ 1523】SPF(割点)

    儿子数大于1的树根或者 Low[v] >= DFN[u]的非树根节点v 就是割点. #include <cstdio> #include <cstring> const ...

  8. C++强制类型转换操作符 static_cast

    static_cast是一个强制类型转换操作符.强制类型转换,也称为显式转换,C++中强制类型转换操作符有static_cast.dynamic_cast.const_cast.reinterpert ...

  9. VisualSVN Server和Subversion的联系

    VisualSVN Server是只能在Windows平台上搭建的SVN服务器,内核使用的是Subversion,做了整合:apache+subversion+WMI(实现操作界面等). 用这个的好处 ...

  10. 洛谷P1410 子序列

    题目描述 给定一个长度为N(N为偶数)的序列,问能否将其划分为两个长度为N/2的严格递增子序列, 输入输出格式 输入格式: 若干行,每行表示一组数据.对于每组数据,首先输入一个整数N,表示序列的长度. ...