java 基础之 反射技术
1. java代码
在 java 语言中最核心的就是代码的运行, 按照面向对象的思想,在调用java代码时往往需要先创建对象,再调用方法, 而写在方法中的即所谓的java 代码
一段java代码在程序运行期间会经历三个阶段: source-->class-->runtime
2. Class 对象
在java中用一个Class对象来表示一个java类的class阶段
Class对象封装了一个java类中定义的成员变量、成员方法、构造方法、类名、包名等
获得class对象的三种方式和区别
// 1. 根据给定的类名来获得 用于类加载
String classname ="cn.itcast.reflect.Person"; //来自配置文件
Class clazz = Class.forName(classname); // 此对象代表Person.class
// 2. 如果拿到了对象,不知道是什么类型 用于获得对象的类型
Object obj = new Person();
Class clazz1 = obj.getClass(); // 获得对象具体的类型
// 3. 如果是明确地获得某个类的Class对象 主要用于传参
Class clazz2 = Person.class;
// 在java中所有的类型都会对应一个Class对象 int Integer
Class intClazz = int.class;
Class intarrClazz = int[].class;
Class voidClazz = void.class;
3. 反射的概念
反射就是获得一个java类的各个组成部分
// 反射类的成员方法
Class clazz = Person.class;
Method method =clazz.getMethod(methodName, new Class[]{paramClazz1, paramClazz2});
method.invoke();
// 反射类的构造函数
Constructor con =clazz.getConstructor(new Class[]{paramClazz1, paramClazz2,...})
con.newInstance(params...)
// 反射类的属性
Field field =clazz.getField(fieldName);
field.setAccessible(true);
field.setObject(value);
4. 反射用在哪里
到底框架是什么? 框架就是将开发中大量重复的代码集中起来写个通用的程序
框架就是用反射来实现的
框架需要现在的类调用将来写的类
框架是将来的程序员调用的,框架不能实现完整的功能,框架只是一些一些通用的代码
框架要运行一定会依赖将来写的类
现在写的类要调用将来写的类,我们先针对接口进行调用,将来的类需要实现接口,那么方法就固定了
但是将来写的类的类名我们无法获知,这时就需要调用者通过配置文件告诉框架具体的类名
Person.java
// 1. 根据给定的类名来获得 用于类加载
package xgp_reflect;
import java.awt.List;
import java.io.InputStream;
public class Person {
publicString name= "aaaa";
privatestatic int password=123;
//1、类构造函数
publicPerson(){
System.out.println("无参数构造函数!");
}
publicPerson(String name){
System.out.println(name);
}
publicPerson(String name, int password){
System.out.println(name+password);
}
privatePerson(List list){
System.out.println("list");
}
//2、方法
publicvoid aa1(){
System.out.println("aa1无参数方法");
}
publicvoid aa1(String name, int password){
System.out.println(name+":"+password+"两个参数的方法");
}
publicvoid aa1(InputStream in){
System.out.println(in);
}
publicClass[] aa1(String name, int[] password){
returnnew Class[]{String.class} ;
}
privatestatic void aa1(int num){
System.out.println(num+"静态方法");
}
public static void main(String[] args){
System.out.println("main");
}
}
Demo01.java
package xgp_reflect;
public class Demo01 {
/**
*
* 反射,加载类,获得类的字节码
* @throws ClassNotFoundException
*/
publicstatic void main(String[] args) throws ClassNotFoundException {
//方法1
Classclazz = Class.forName("/stringjava/src/xgp_reflect/Person.java");
//方法2
Classclazz2 = new Person().getClass();
//方法3
Classclazz3 = Person.class;
}
}
Demo02.java
// package xgp_reflect;
import java.awt.List;
importjava.lang.reflect.Constructor;
importjava.lang.reflect.InvocationTargetException;
import java.util.ArrayList;
import org.junit.Test;
public class Demo02 {
/**
* 反射类的构造函数,创建类的对象
*/
@Test
//反射构造函数publicPerson()
publicvoid test1() throws Exception{
Classclazz = Class.forName("xgp_reflect.Person");
Constructorc = clazz.getConstructor(null);
Personp = (Person) c.newInstance(null);
System.out.println(p.name);
}
//反射构造函数publicPerson(String name)
@Test
publicvoid test2() throws Exception{
Classclazz = Class.forName("xgp_reflect.Person");
Constructorc = clazz.getConstructor(String.class);
Personp = (Person) c.newInstance("xxxx");
System.out.println(p.name);
}
//反射构造函数publicPerson(String name, int password)
@Test
publicvoid test3() throws Exception{
Classclazz = Class.forName("xgp_reflect.Person");
Constructorc = clazz.getConstructor(String.class, int.class);
Personp = (Person) c.newInstance("xiaoguoping",25);
System.out.println(p.name);
}
//反射构造函数publicPerson(List list)
@Test
publicvoid test4() throws Exception{
Classclazz = Class.forName("xgp_reflect.Person");
Constructorc = clazz.getDeclaredConstructor(List.class);
c.setAccessible(true);
Personp = (Person) c.newInstance(new List());
System.out.println(p.name);
}
//无参数构造函数的另一种方法
@Test
publicvoid test5() throws Exception{
Classclazz = Class.forName("xgp_reflect.Person");
Personp = (Person) clazz.newInstance();
System.out.println(p.name);
}
}
Demo03.java
// package xgp_reflect;
import java.io.FileInputStream;
import java.io.InputStream;
import java.lang.reflect.Method;
import org.junit.Test;
public class Demo3 {
/**
* 反射类的方法
*/
@Test
//反射类的方法--publicvoid aa1()
publicvoid test1() throws Exception{
Personp = new Person();
Classclazz = Class.forName("xgp_reflect.Person");
Methodmethod = clazz.getMethod("aa1", null);
method.invoke(p,null);
}
@Test
//反射类的方法--publicvoid aa1(String name, int password)
publicvoid test2() throws Exception{
Personp = new Person();
Classclazz = Class.forName("xgp_reflect.Person");
Methodmethod= clazz.getMethod("aa1", String.class,int.class);
method.invoke(p,"xiaoguoping",25);
}
@Test
//反射类的方法--publicClass[] aa1(String name, int[] password)
publicvoid test3() throws Exception{
Personp = new Person();
Classclazz = Class.forName("xgp_reflect.Person");
Methodmethod= clazz.getMethod("aa1", String.class,int[].class);
Classcs[] = (Class[]) method.invoke(p, "xiaoguoping", new int[]{1,2});
System.out.println(cs[0]);
}
@Test
//反射类的方法--publicvoid aa1(InputStream in)
publicvoid test4() throws Exception{
Personp = new Person();
Classclazz = Class.forName("xgp_reflect.Person");
Methodmethod= clazz.getMethod("aa1",InputStream.class);
method.invoke(p,newFileInputStream("C:\\unknow.log"));
}
@Test
//反射类的方法--privatestatic void aa1(int num)
publicvoid test5() throws Exception{
//Personp = new Person();静态方法可以不传对象
Classclazz = Class.forName("xgp_reflect.Person");
Methodmethod= clazz.getDeclaredMethod("aa1",int.class);
method.setAccessible(true);
method.invoke(null,23);
}
@Test
//反射类的方法--publicstatic void main(String[] args)
publicvoid test6() throws Exception{
Classclazz = Class.forName("xgp_reflect.Person");
Methodmethod= clazz.getMethod("main",String[].class);
//method.invoke(null,newString[]{"aa","bb"});//JDK1.4 main(string s1,string s2)拆开参数赋值
//method.invoke(null,(Object)new String[]{"aa","bb"});
method.invoke(null,new Object[]{new String[]{"aa","bb"}});
}
}
Demo04.java
// package xgp_reflect;
import java.lang.reflect.Field;
import java.lang.reflect.Method;
import org.junit.Test;
public class Demo04 {
/**
* 反射类的字段--属性,封装数据
*/
@Test
//反射类的字段--publicString name= "aaaa";
publicvoid test1() throws Exception{
Personp = new Person();
Classclazz = Class.forName("xgp_reflect.Person");
Fieldfield = clazz.getField("name");
//获取字段的值
Objectvalue= field.get(p);
//获取字段的类型
Classtype = field.getType();
if(type.equals(String.class)) {
Stringsvalue = (String) value;
System.out.println(svalue);//aaaa
}
//设置字段的值
field.set(p,"xxxx");
System.out.println(p.name);//xxxx
}
@Test
//反射类的字段--privatestatic int password=123;
publicvoid test2() throws Exception{
Personp = new Person();
Classclazz = Class.forName("xgp_reflect.Person");
Fieldfield = clazz.getDeclaredField("password");
field.setAccessible(true);
Objectvalue = field.get(p);
System.out.println(value);
}
}
版权声明:本文为小平果原创文章,转载请注明:http://blog.csdn.net/i10630226
java 基础之 反射技术的更多相关文章
- 黑马程序员:Java基础总结----反射
黑马程序员:Java基础总结 反射 ASP.Net+Android+IO开发 . .Net培训 .期待与您交流! 反射 反射的基石:Class类 Class类代表Java类,它的各个实例对象又分别 ...
- 第89节:Java中的反射技术
第89节:Java中的反射技术 反射技术是动态的获取指定的类,和动态的调用类中的内容(没有类前就可以创建对象,将对象的动作完成,这就是动态的获取指定的类). 配置文件把具体实现的类名称定义到配置文件中 ...
- Java基础-零拷贝技术应用案例
Java基础-零拷贝技术应用案例 作者:尹正杰 版权声明:原创作品,谢绝转载!否则将追究法律责任. 零拷贝技术在Hadoop生态圈中很多组件得到应用,典型的比如kafka组件,它就很成功的应用了零拷贝 ...
- Java基础之一反射
反射是框架设计的灵魂 (使用的前提条件:必须先得到代表的字节码的Class,Class类用于表示.class文件(字节码)) 一.反射的概述 JAVA反射机制是在运行状态中,对于任意一个类,都能够 ...
- Java基础之—反射
反射是框架设计的灵魂 (使用的前提条件:必须先得到代表的字节码的Class,Class类用于表示.class文件(字节码)) 一.反射的概述 JAVA反射机制是在运行状态中,对于任意一个类,都能够 ...
- Java基础教程——反射机制
Java反射机制 Java反射机制是Java语言的一个重要特性,使得Java语言具备"动态性": 在运行时获取任意一个对象所属的类的相关信息; 在运行时构造任意一个类的对象: 在运 ...
- 黑马程序员:Java编程_反射技术
=========== ASP.Net+Android+IOS开发..Net培训.期待与您交流!=========== Java类用于描述一类事物的共性,该类事物有什么属性,没有什么属性,至于这个属性 ...
- 黑马程序员——JAVA基础之反射
------Java培训.Android培训.iOS培训..Net培训.期待与您交流! ------- Java 反射是Java语言的一个很重要的特征,它使得Java具体了"动态 ...
- java基础之反射---重要
java反射: 反射是框架设计的灵魂 (使用的前提条件:必须先得到代表的字节码的Class,Class类用于表示.class文件(字节码)): 1:获取Class字节码文件对象的三种方式: /** ...
随机推荐
- Linux基础正则表达式字符汇整(characters)
RE 字符 意义与范例 ^word 意义:待搜寻的字串(word)在行首! 范例:搜寻行首为 # 开始的那一行,并列出行号 grep -n '^#' regular_express.txt word$ ...
- ORALCE EBS ALERT 初体验
Oracle EBS Alert Alert 是一种Oracle系统中的一种机制,它可以监视系统数据库,在规定的情况下给规定用户一个通知,通知可以是邮件或者其他形式,在标注的系统和客户化系统中都是可以 ...
- Effective STL 为包含指针的关联容器指定比较类型
// 为包含指针的关联容器指定比较类型.cpp : 定义控制台应用程序的入口点. // #include "stdafx.h" #include <set> #incl ...
- Oracle 中Return 和exit的区别
在Oracle存储过程中,使用Return 时,如果执行到Return语句,会跳出整个语句(如果是循环,会跳出整个循环),将不再执行,也就是结束了整个存储过程. 下面就用一个例子来说明一下 ,这个存储 ...
- css中bfc和ifc
bfc定义:块级格式化上下文,他是一个独立的渲染区域,他规定了这个内部如何布局,并且与这个区域的外部毫不相干.BFC布局规则: 内部的Box会在垂直方向,一个接一个地放置.Box垂直方向的距离由mar ...
- Python 3 中的json模块使用
1. 概述 JSON (JavaScript Object Notation)是一种使用广泛的轻量数据格式. Python标准库中的json模块提供了JSON数据的处理功能. Python中一种非常常 ...
- insertion sort list (使用插入排序给链表排序)
Sort a linked list using insertion sort. 对于数组的插入排序,可以参看排序算法入门之插入排序(java实现),遍历每个元素,然后相当于把每个元素插入到前面已经排 ...
- 信息化建设中的IT规划精要
IT规划在信息化建设中发挥着"定位"和"导航"的作用,IT规划理论方法更是博大精深,细细讲来,会成为IT版本的"一千零一夜".因此,本文以& ...
- jvm性能优化及内存分区
jvm性能优化及内存分区 2012-09-17 15:51:37 分类: Java Some of the default values for Sun JVMs are listed below. ...
- Win7下 Python中文正则的奇异表现
首先贴Win32下的直接Python shell下的测试结果: Python 2.7.6 (default, Nov 10 2013, 19:24:18) [MSC v.1500 32 bit (In ...