<rt id="bn8ez"></rt>
<label id="bn8ez"></label>

  • <span id="bn8ez"></span>

    <label id="bn8ez"><meter id="bn8ez"></meter></label>

    和風細雨

    世上本無難事,心以為難,斯乃真難。茍不存一難之見于心,則運用之術自出。

    反射Reflection綜述

    反射Reflection是Java被視為動態語言的一個關鍵性質.這個機制允許程序在運行時通過Reflection APIs得到任何一個已知名稱的類的相關信息,包括其構造方法,父類,實現的接口,成員變量(field)和成員方法(method)的相關信息,并可在運行時改變成員變量的值或調用其方法.反射的高度靈活的特性使得它成為Java語言中最具魔力和活力的部分,它是許多流行框架的實現基礎,如Struts,Spring和Hibernate,本篇將列舉一些反射常見的API:

    實現反射機制的類
    在JDK中,主要由以下類來實現Java反射機制,這些類都位于java.lang.reflect包中:
    Class類:代表一個類。
    Field 類:代表類的成員變量(成員變量也稱為類的屬性)。
    Method類:代表類的方法。
    Constructor 類:代表類的構造方法。
    Array類:提供了動態創建數組,以及訪問數組的元素的靜態方法。

    反射的源頭:Class類
    Java類繼承體系的是一個單根體系,所有類的都起源于Object類,其內聲明了數個應該在所有Java class中被改寫的methods:hashCode()、equals()、clone()、toString()、getClass()等。其中getClass()返回一個Class object。當一個class被加載,或當加載器(class loader)的defineClass()被JVM調用,JVM 便自動產生一個Class object。
    由于在java.lang.Object 類中定義了getClass()方法,因此對于任意一個Java對象,都可以通過此方法獲得對象的類型。
    Class類對象代表了Java應用程序中的各種類和接口.這些類不是程序代碼生成的,而是在Java虛擬機(JVM)裝入各種類時生成的.

    Static class forName(String className)
    這個方法返回以className為名字的Class對象。
    Object newInstance()
    創建該Class對象代表的類的一個實例,類似調用一個無參數的構造函數。這個方法要求類必須具有一個無參構造函數,如果沒有時調用此方法程序會拋出一個java.lang.InstantiationException異常,這也是許多框架要求類具有一個無參構造函數的根本原因
    package com.sitinspring;

    public class Member{
      
    private String name;
      
    private int age;
      
    private float salary;
      
      
    public Member(){
        name
    ="Unknown";
        age
    =20;
        salary
    =1.00f;
      }
      
      
    public String toString(){
        
    return "名稱="+name+" 年齡="+age+" 薪水="+salary;
      }
      
      
    public static void main(String[] args){
        
    try{
          Class cls
    =Class.forName("com.sitinspring.Member");
          Member member
    =(Member)cls.newInstance();
          System.out.println(member);
        }
        
    catch(Exception ex){
          ex.printStackTrace();
        }
      }
    }

    Class getSuperclass()
    返回該Class對象代表的類的父類。如果該Class是Object,接口,基本數據類型或void,則返回nulll,如果這個類對象是數組,則返回Object類的類對象
    public class Member extends Thread implements Comparable{
      
    private String name;
      
    private int age;
      
    private float salary;
      
      
    public Member(){
        name
    ="Unknown";
        age
    =20;
        salary
    =1.00f;
      }
      
      
    public String toString(){
        
    return "名稱="+name+" 年齡="+age+" 薪水="+salary;
      }
      
      
    public int compareTo(Object obj){
        Member another
    =(Member)obj;
        
        
    return this.age-another.age;
      }
      
      
    public static void main(String[] args){
        System.out.println(Member.
    class.getSuperclass());
        System.out.println(Object.
    class.getSuperclass());
        System.out.println(Comparable.
    class.getSuperclass());
        System.out.println(
    int.class.getSuperclass());
        System.out.println(
    void.class.getSuperclass());
        System.out.println(String[].
    class.getSuperclass());
      }
    }
    Class[] getInterfaces()
    返回該Class對象實現的接口。
    public class Member implements Comparable,Runnable{
      
    private String name;
      
    private int age;
      
    private float salary;
      
      
    public Member(){
        name
    ="Unknown";
        age
    =20;
        salary
    =1.00f;
      }
      
      
    public String toString(){
        
    return "名稱="+name+" 年齡="+age+" 薪水="+salary;
      }
      
      
    public int compareTo(Object obj){
        Member another
    =(Member)obj;
        
        
    return this.age-another.age;
      }
      
      
    public void run(){
        
      }
      
      
    public static void main(String[] args){
        
    for(Class cls:Member.class.getInterfaces()){
          System.out.println(cls.toString());
        }
      }
    }
    輸出:
    interface java.lang.Comparable
    interface java.lang.Runnable

    Construtor[] getConstructors()
    Construtor[] getDeclaredConstructors()
    Construtor[] getConstructors(Class[] parameterTypes)
    Construtor[] getDeclaredConstructors(Class[] parameterTypes)

    返回構造函數,如果有parameterTypes,返回參數類型為parameterTypes的構造函數,Declared是指類中聲明的所有構造函數,如果沒有Declared,則只返回共有構造函數。
    public class Member {
      
    private String name;

      
    private int age;

      
    private float salary;

      
    public Member() {
        name 
    = "Unknown";
        age 
    = 20;
        salary 
    = 1.00f;
      }

      
    public Member(String name, int age, float salary) {
        
    this.name = name;
        
    this.age = age;
        
    this.salary = salary;
      }

      
    public String toString() {
        
    return "名稱=" + name + " 年齡=" + age + " 薪水=" + salary;
      }

      
    public static void main(String[] args) {
        
    for (Constructor cls : Member.class.getConstructors()) {
          System.out.println(cls.toString());
        }

        
    try {
          Class cls 
    = Class.forName("com.sitinspring.Member");
          Constructor con 
    =cls.getConstructor(new Class[]{String.classint.class,float.class});
          Member member 
    = (Member) con.newInstance(new Object[] {
              
    new String("Sitinspring"), new Integer(30),
              
    new Float(20000) });
          System.out.println(member); 
        } 
    catch (Exception e) {
          e.printStackTrace();
        }
      }
    }

    Field[] getFields()
    Field[] getDeclaredFields()
    Field getField(String name)
    Field[] getDeclaredFields(String name)

    返回成員變量。如果有name參數,返回名字是name的成員變量,Declared指聲明中所有的成員變量,如果沒有Declared,則只返回公有成員變量。
    public class Member {
      
    private String name;

      
    private int age;

      
    private float salary;
      
      
    public String field1;
      
    protected String field2;

      
    public static void main(String[] args) {
        
    for (Field field : Member.class.getFields()) {
          System.out.println(field);
        }
        
        
    for (Field field : Member.class.getDeclaredFields()) {
          System.out.println(field.getName());
        }
      }
    }

    輸出:
    public java.lang.String com.sitinspring.Member.field1
    name
    age
    salary
    field1
    field2

    Method[] getMethods()
    Method[] getDeclaredMethods()
    Method getMethod(String name,Class[] parameterTypes)
    Method[] getDeclaredMethods(String name ,Class[] parameterTypes)

    返回類的方法,如果有name和parameterTypes參數,返回名字是name,且有parameterTypes參數列表的方法、Declared指聲明中所有的方法(包括public,private,protected),如果沒有Declared,則只返回公有方法。

    Method類有一個重要方法
    Object invoke(Object obj,Object[] arg),
    通過它可以進行類方法調用,在后面的例子中會見到。
    public class Member {
      
    private String name;

      
    private int age;

      
    private float salary;

      
    public Member() {
        name 
    = "Unknown";
        age 
    = 20;
        salary 
    = 1.00f;
      }

      
    public String toString() {
        
    return "名稱=" + name + " 年齡=" + age + " 薪水=" + salary;
      }
      
      
    public int getAge() {
        
    return age;
      }

      
    protected String getName() {
        
    return name;
      }

      
    private float getSalary() {
        
    return salary;
      }
      
      
    public static void main(String[] args) {
        
    for (Method method : Member.class.getMethods()) {
          System.out.println(method);
        }
        System.out.println(
    "--------------");
        
    for (Method method : Member.class.getDeclaredMethods()) {
          System.out.println(method);
        }
      }
    }

    調用類的方法
    Method類有一個重要方法
    Object invoke(Object obj,Object[] arg),
    Object代表返回值,obj是類實例, arg是參數數組。

    這個方法能調用實例的一個方法。如右:
    public class Caculator{
      
    public int add(int op1,int op2){
        
    return op1+op2;
      }
      
      
    public int substract(int op1,int op2){
        
    return op1-op2;
      }
      
      
    public static void main(String[] args){
        
    try{
          Caculator caculator
    =new Caculator();
          
          Method addMethod 
    = caculator.getClass().getMethod(
              
    "add",
              
    new Class[] { int.class,int.class });

          Object result1
    =addMethod.invoke(caculator, new Object[] { 1,2 });
          System.out.println(
    "和="+result1);
          
          Method substractMethod 
    = caculator.getClass().getMethod(
              
    "substract",
              
    new Class[] { int.class,int.class });
          
          Object result2
    =substractMethod.invoke(caculator, new Object[] { 3,4 });
          System.out.println(
    "差="+result2);
        }
        
    catch(Exception ex){
          ex.printStackTrace();
        }
      }
    }

    通過Field對對象進行設值取值請見:http://m.tkk7.com/sitinspring/archive/2008/01/03/172455.html

    通過Method對對象進行設值取值請見:
    http://m.tkk7.com/sitinspring/archive/2008/01/05/172970.html

    posted on 2008-02-22 09:19 和風細雨 閱讀(212) 評論(0)  編輯  收藏


    只有注冊用戶登錄后才能發表評論。


    網站導航:
     
    主站蜘蛛池模板: 久久久久亚洲精品无码网址色欲 | 亚洲中文无码卡通动漫野外| 久久九九免费高清视频| 亚洲精品无码成人片在线观看| 日韩精品亚洲专区在线影视| 日本媚薬痉挛在线观看免费| 成人永久免费高清| 亚洲色欲啪啪久久WWW综合网| 毛片免费视频观看| 国产精品日本亚洲777| 中文字幕在线视频免费| 青青在线久青草免费观看| 亚洲H在线播放在线观看H| 成年美女黄网站18禁免费| 亚洲人成人伊人成综合网无码| 国产黄在线播放免费观看| 嫩草影院免费观看| 国产亚洲一区二区在线观看| 免费国产午夜高清在线视频| 日韩一区二区免费视频| 亚洲成av人片天堂网无码】| 特级精品毛片免费观看| 国产精品另类激情久久久免费| 四虎影视在线看免费观看| 亚洲一区无码中文字幕 | 成人区精品一区二区不卡亚洲| 最近中文字幕免费mv视频8| 美女黄频免费网站| 亚洲国产精品特色大片观看完整版| 免费无码成人AV在线播放不卡| 亚洲А∨精品天堂在线| 9久久免费国产精品特黄| 67pao强力打造67194在线午夜亚洲 | 99re6热视频精品免费观看| 麻豆狠色伊人亚洲综合网站 | 免费观看午夜在线欧差毛片| 亚洲男人的天堂在线播放| 免费在线不卡视频| 久久免费视频99| 国产L精品国产亚洲区久久| 久久久久久国产精品免费免费男同|