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字节码文件对象的三种方式: /** ...
随机推荐
- Android开发技巧——自定义控件之自定义属性
Android开发技巧--自定义控件之自定义属性 掌握自定义控件是很重要的,因为通过自定义控件,能够:解决UI问题,优化布局性能,简化布局代码. 上一篇讲了如何通过xml把几个控件组织起来,并继承某个 ...
- masm的一些常用编译选项
ml命令行选项: /Dsymbol[=value] 定义给定名称的文本宏 /Fl 生成lst文件 /Sn lst文件中关闭符号表 /I 设置include文件的路径 /link 发送给link的连接器 ...
- android + php 后台开发
android+php 安卓与服务器的数据交互 在我们进行android开发的时候,避免不了的要进行登录注册,个人信息获取,数据交互等等这一系列的操作.这样就需要进行android端与服务器端进行数据 ...
- oracle 数据库 date + 1 转载
http://blog.csdn.net/yjp198713/article/details/18131871 oracle 求两个时间点直接的分钟.小时数 1.获得时间差毫秒数: select ce ...
- JavaScript设计模式之一封装
对于熟悉C#和Java的兄弟们,面向对象的三大思想(封装,继承,多态)肯定是了解的,今天我想讲讲如何在Javascript中利用封装这个特性,开讲! 我们会把现实中的一些事物抽象成一个Class并且把 ...
- Day2_and_Day3 文件操作
文件修改操作: 文件的修改操作:文件并没有修改操作,实际是将一个编写的新文件覆盖了原有的文件 替换文件中的某个内容: with open('old.txt','r',encoding='utf-8') ...
- Python-Web框架之 - 利用SQLALchemy创建与数据库MySQL的连接, 详解用Flask时会遇到的一些大坑 !
经过这个小项目算是对Django与Flask这两个web框架有了新的认识 , Django本身的轮子非常齐全 , 套路也很固定 , 新手在接触Django框架时 , 不会陷入到处找轮子的大坑 ; 那么 ...
- 人手一份核武器 - Hacking Team 泄露(开源)资料导览手册
https://zhuanlan.zhihu.com/p/20102713 author:蒸米 0x00 序 事先声明本人并不是全栈安全工程师,仅仅是移动安全小菜一枚,所以对泄漏资料的分析难免会有疏忽 ...
- Ocelot中文文档-授权
Ocelot支持基于声明的授权. 这意味着如果您有要授权的路由,您可以将以下内容添加到您的ReRoute配置中. "RouteClaimsRequirement": { " ...
- Nginx日志自动按日期存储
Nginx ("engine x") 是一个高性能的 HTTP 和 反向代理 服务器,也是一个 IMAP/POP3/SMTP 代理服务器,因它的稳定性.丰富的功能集.示例配置文件和 ...