以下是sun公司提供的反射机制中的类
java.lang.Class; //代表整个类
java.lang . reflect. Constructor ; //代表类中的构造方法
java.lang. reflect.Field; //代表类的属性
java.lang. reflect .Method; //代表类中的方法
java.lang . reflect.Modifier; //代表类中的修饰符
//整个类class User (private string name; //类中的属性public User() {} //构造方法public void m1 (){} //方法) //像 private public 这都是修饰符
反射机制的作用----
1.反编译:.class--->java
2.通过反射机制访问Java中类的属性,方法,构造方法等。
反射机制的缺点
反射是一种强大的工具,但也存在一些不足。
性能问题。
使用反射基本上是一种解释操作, 我们可以告诉JVM我们希望做什
么并且它满足我们的要求。用于字段和方法接入时反射要远慢于直接代码。性能问题的程度取决于程序中是如何使用反射的,如果它作为程序运行中相对很少涉及的
部分,缓慢的性能将不会是个问题,
使用反射会模糊程序内部实际要发生的事情,程序人员希望在原代码中看到程序的逻辑,反射绕过了源代码的技术会带来维护问题.反射代码比相应的直接代码更复杂。要保守的使用反射
获取Class 的三种方法
首先准备一个已经编译好的类。。
public class Employee {//Filedprivate String name;//Constructorpublic Employee(){}public Employee(String name){this.name=name;}public void work(){System.out.println(name+"在工作!");}}
![70b3cd9c71786116477f299aa7028938.png](https://i-blog.csdnimg.cn/blog_migrate/6e1f9d739613d6f3991e0c4ad62aa57d.jpeg)
import java.util.*;public class ReflectTest01 {//获取Class对象的三种方式public static void main(String[] args) {try {//第一种方式Class c1=Class.forName("Employee");//c1引用-保存内存地址指向堆中的对象, 该对象代表的是Employee整个类} catch (ClassNotFoundException e) {// TODO Auto-generated catch blocke.printStackTrace();}//第二种方式//java中每个类型都有class属性Class c2=Employee.class;//第三种方式//java中任何一个对象都有getClass方法Employee e=new Employee();Class c3=e.getClass(); //c3是运行时类 (Employee)//----------------------------例如Class d1=Date.class;try {Class d2=Class.forName("java.util.Date");//必须写类全名,类全名带有包名} catch (ClassNotFoundException e1) {// TODO Auto-generated catch blocke1.printStackTrace();}Date d=new Date(0);Class d3=d.getClass();}}
public class ReflectTest02 {public static void main(String[] args) throws ClassNotFoundException {Class.forName("A"); //将A.class文件装载到JVM中的过程Class c=A.class; //这个不会执行静态语句块}}class A{static{System.out.println("A------------");}}
![70100e9b9a3c8d3e3b12280f0a221a97.png](https://i-blog.csdnimg.cn/blog_migrate/6a443871688cc1bd393d81acf89af4f7.jpeg)
import java.text.SimpleDateFormat;import java.util.Date;import java.util.logging.SimpleFormatter;//获取class类型的对象后,可以创建该类的对象public class ReflectTest03 {public static void main(String[] args) throws ClassNotFoundException, InstantiationException, IllegalAccessException {Class c=Class.forName("Employee");//创建此Class对象所表示的类的一个新实例 Object o=c.newInstance(); //调用了Employee的无参构造方法 //---------------------------------例 Class c1=Class.forName("java.util.Date"); Object o1=c1.newInstance(); //调用Date类的无参构造方法,相当于获取系统时间 if(o1 instanceof Date){ //它的作用是判断其左边对象是否为其右边类的实例 Date t=(Date)o1; System.out.println(new SimpleDateFormat("yyyy-MM-dd HH:mm:ss SSS").format(t)); }}}
import java.util.*;//关于java中的可变长参数public class Test01 {public static void m1(int...a){ //此方法在调用时,传递的实参可以是0-N个System.out.println("Test");}public static void m1(int i){ //如果有精确匹配的方法,则调用该方法,不会执行变长参数的方法System.out.println(i);}//可变长参数可以等同看作数组public static void m2(String...args){for(int i=0;i