反射机制是在运行状态中,对于任意一个类,都能够知道这个类的所有属性和方法;对于任意一个对象,都能够调用它的任意一个方法和属性;这种动态获取的信息以及动态调用对象的方法的功能称为java语言的反射机制。【翻译于 官方文档】
本篇將從以下幾個面向講述反射的知識:
class 的使用
方法的反射
建構函數的反射
成員變數的反射
在物件導向的世界裡,萬物皆物件。類別是對象,類別是java.lang.Class類別的實例對象。另外class類別只有java虛擬機器才能new出來。任何一個類別都是Class 類別的實例物件。這實例物件有三種表達方式:
public class User{
}
public class ClassTest{
User u=new User();
//方式1 :
Class c1=User.class;
//方式2:
Class c2=u.getClass();
//方式3:
Class c3=Class.forName(" com.forezp.User");
//可以透過類別的型別建立該類別的實例物件
User user=(User)c1.newInstance();
}
Class.forName(類別的全名);此方法不僅表示了類別的類型,也代表了動態載入類別。編譯時刻載入類別是靜態載入、執行時刻載入類別是動態載入類別。
基本的資料型,void關鍵字都Class 類別的實例;可以透過getame();getSimpleName()取得類別的名稱。
Class c1=String.class;
Class c2=int.class;
Class c3=void.class;
System.out.println(c1.getName());
System.out.println(c2.getSimpleName());
取得類別的所有方法,並列印出來:
public static void printClassInfo(Object object){
Class c=object .getClass();
System.out.println("類別的名稱:"+c.getName());
/**
* 一個成員方法是一個method物件
* 一個成員方法是一個method物件
* 一個成員方法是一個method物件
* 一個成員方法為一個method物件
* 有一個成員方法為一個的public方法,包含父類別所繼承的public
getDeclared.)()取得此類別的所有繼承方法,包括使用該類別時包含的方法。
*/# # meth meth c.getMethods();//取得方法
//取得所以的方法,包括private ,c.getDeclaredMethods();
# for(int i=0;i<methods.length;) {
//得到方法的回傳類型
Class returnType=methods[i].getReturnType();
//得到方法名:
System.out.print(methods[i].getName()+"(");
Class[] parameterTypes=methods[Class]. class1:parameterTypes){
System.out.print(class1.getName()+",");
}); }
}
public class ReflectTest {
public static void main(String[] args){
# String s="ss"" "#tilo"#); }
}
執行:
类的名称:java.lang.String booleanequals(java.lang.Object,) java.lang.StringtoString() inthashCode() …
Class c=o.getClass();
/**
* getFileds()取得public
* getDeclaredFields()取得所有
*/
Field[] **&*/
Field[] **&*/
Field[] **&*/
.ecfileed
# for(Field f:fileds){
//取得成員變數的型別
Class filedType=f.getType() 問題Name()+" " +f.getName());
}
}
public static void main(String[] args){
til. printClassInfo(s);
ClassUtil.printFiledInfo(s);
}
運行:
[C value int hash long serialVersionUID [Ljava.io.ObjectStreamField; serialPersistentFields java.util.Comparator CASE_INSENSITIVE_ORDER int HASHING_SEED int hash32
public static void printConstructInfo(Object o){
Class c=o.getClass();
Constructor[] constructors=c.getDeclaredConstructors();
for (Constructor con:constructors){
System.out.print(con.getName()+”(“);
Class[] typeParas=con.getParameterTypes();
for (Class class1:typeParas){
System.out.print(class1.getName()+” ,”);
}
System.out.println(“)”);
}
}
public static void main(String[] args){
String s="ss";
//ClassUtil.printClassInfo(s);
//ClassUtil.printFiledInfo(s);
ClassUtil.printConstructInfo(s);
}
运行:
java.lang.String([B ,) java.lang.String([B ,int ,int ,) java.lang.String([B ,java.nio.charset.Charset ,) java.lang.String([B ,java.lang.String ,) java.lang.String([B ,int ,int ,java.nio.charset.Charset ,) java.lang.String(int ,int ,[C ,) java.lang.String([C ,boolean ,) java.lang.String(java.lang.StringBuilder ,) java.lang.String(java.lang.StringBuffer ,) ...
获取一个方法:需要获取方法的名称和方法的参数才能决定一个方法。
方法的反射操作:
method.invoke(对象,参数列表);
举个例子:
class A{
public void add(int a,int b){
System.out.print(a+b);
}
public void toUpper(String a){
System.out.print(a.toUpperCase());
}
}
public static void main(String[] args) {
A a=new A();
Class c=a.getClass();
try {
Method method=c.getMethod("add",new Class[]{int.class,int.class});
//也可以 Method method=c.getMethod("add",int.class,int.class);
//方法的反射操作
method.invoke(a,10,10);
}catch (Exception e){
e.printStackTrace();
}
}
运行:
20
本篇文章已经讲解了java反射的基本用法, 它可以在运行时判断任意一个对象所属的类;在运行时构造任意一个类的对象;在运行时判断任意一个类所具有的成员变量和方法;在运行时调用任意一个对象的方法;生成动态代理。
以上是需要掌握的Java反射機制知識總結的詳細內容。更多資訊請關注PHP中文網其他相關文章!