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

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

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

    posts - 11,  comments - 0,  trackbacks - 0

     

    在java程序中每一個(gè)類都有一個(gè)Class對象,被保存在同名的.Class對象當(dāng)中,JVM會(huì)使用類加載器加載Class文件生成類的對象信息.

    當(dāng)我們創(chuàng)建一個(gè)類的對象或者調(diào)用這個(gè)對象的靜態(tài)方法,jvm會(huì)自動(dòng)加載類的對象信息

    獲得類的對象信息

    我們一般常用用兩種方式獲得類的對象信息.

    1. 我們可以用Class.forName()方法動(dòng)態(tài)的根據(jù)類名獲得一個(gè)類的Class對象.

      1:     /**
      2:      * 使用此方法為自動(dòng)初始化靜態(tài)變量和執(zhí)行static塊的代碼
      3:      * 如果找不到對象會(huì)拋出一個(gè)ClassNotFoundException
      4:      */
      5:     Class second = Class.forName("classLoad.Second");

    2. 我們還可以用Class class = ClassName.class 來直接獲取一個(gè)類的類型信息,但用它和Class.forName()獲取類的對象

    引用信息在靜態(tài)塊時(shí)的執(zhí)行時(shí)間上不同,看下面的例子:

    一個(gè)普通類信息

      1: interface Interface{
      2:   public static String interFlag = "接口";
      3:   
      4: }
      5: 
      6: class Parent implements Interface{
      7:   public static String parntFLAG = "父類靜態(tài)變量";
      8:   static{
      9:     final  String flag2 = "flag2";//static 區(qū)中只能用final修飾
     10:     System.out.println("我在父類靜態(tài)區(qū)里面!"+parntFLAG);
     11:   }
     12:   
     13:   public  Parent(){
     14:     System.out.println("我在父類構(gòu)造函數(shù)里面!");
     15:   }
     16: }
     17: 
     18: 
     19: class Son extends  Parent{
     20:   public static String sonFLAG = "子類類靜態(tài)變量";
     21:   static{
     22:     System.out.println("我在子類靜態(tài)區(qū)里面!"+sonFLAG);
     23:   }
     24:   
     25:   public Son(){
     26:     System.out.println("我在子類構(gòu)造函數(shù)里面!");
     27:   }
     28: }
      1: interface Interface{
      2:   public static String interFlag = "接口";
      3:   
      4: }
      5: 
      6: class Parent implements Interface{
      7:   public static String parntFLAG = "父類靜態(tài)變量";
      8:   static{
      9:     final  String flag2 = "flag2";//static 區(qū)中只能用final修飾
     10:     System.out.println("我在父類靜態(tài)區(qū)里面!"+parntFLAG);
     11:   }
     12:   
     13:   public  Parent(){
     14:     System.out.println("我在父類構(gòu)造函數(shù)里面!");
     15:   }
     16: }
     17: 
     18: 
     19: class Son extends  Parent{
     20:   public static String sonFLAG = "子類類靜態(tài)變量";
     21:   static{
     22:     System.out.println("我在子類靜態(tài)區(qū)里面!"+sonFLAG);
     23:   }
     24:   
     25:   public Son(){
     26:     System.out.println("我在子類構(gòu)造函數(shù)里面!");
     27:   }
     28: }

    使用這種方法引用類的對象不會(huì)始化靜態(tài)變量和執(zhí)行靜態(tài)塊信息,這些代碼方法會(huì)在首次引用時(shí)執(zhí)行.

    如下引用父類的靜態(tài)變量,不會(huì)執(zhí)行子類的靜態(tài)塊.

      1: public class ClassLoad {
      2:   public static void main(String[] args) throws ClassNotFoundException  {
      3:     
      4:     //Son son = new Son();
      5:     /**
      6:      * 我們使用一個(gè)類的時(shí)候需要進(jìn)行以下3項(xiàng)工作.
      7:      * 1.加載,
      8:      * 2.鏈接
      9:      * 3.初始化,此步會(huì)初始化靜態(tài)變量和執(zhí)行靜態(tài)塊信息,但是這種方法會(huì)在
     10:      * 真正調(diào)用方法時(shí)執(zhí)行
     11:      */
     12:     Class son = Son.class;
     13:     System.out.println("靜態(tài)區(qū)的初始化會(huì)在調(diào)用時(shí)執(zhí)行!");
     14:     // parntFLAG 是父類的靜態(tài)變量 
     15:     // 此處只會(huì)執(zhí)行父類的靜態(tài)快
     16:     System.out.println(Son.parntFLAG);
     17: 
     18:     /**
     19:      * 運(yùn)行結(jié)果
     20:      *靜態(tài)區(qū)的初始化會(huì)在調(diào)用時(shí)執(zhí)行!
     21:      *我在父類靜態(tài)區(qū)里面!父類靜態(tài)變量
     22:      *父類靜態(tài)變量
     23:      */
     24:   }
     25: }

    打印子類的靜態(tài)變量,所有的代碼都會(huì)執(zhí)行

      1: 
      2: public class ClassLoad {
      3:   public static void main(String[] args) throws ClassNotFoundException  {
      4:     
      5:     //Son son = new Son();
      6:     /**
      7:      * 我們使用一個(gè)類的時(shí)候需要進(jìn)行以下3項(xiàng)工作.
      8:      * 1.加載,
      9:      * 2.鏈接
     10:      * 3.初始化,此步會(huì)初始化靜態(tài)變量和執(zhí)行靜態(tài)塊信息,但是這種方法會(huì)在
     11:      * 真正調(diào)用方法時(shí)執(zhí)行
     12:      */
     13:     Class son = Son.class;
     14:     System.out.println("靜態(tài)區(qū)的初始化會(huì)在調(diào)用時(shí)執(zhí)行!");
     15:     // parntFLAG 是父類的靜態(tài)變量 
     16:     // 此處只會(huì)執(zhí)行父類的靜態(tài)快
     17:     System.out.println(Son.sonFLAG);
     18: 
     19:     /**
     20:      * 運(yùn)行結(jié)果
     21:      * 靜態(tài)區(qū)的初始化會(huì)在調(diào)用時(shí)執(zhí)行!
     22:      * 我在父類靜態(tài)區(qū)里面!父類靜態(tài)變量
     23:      * 我在子類靜態(tài)區(qū)里面!子類類靜態(tài)變量
     24:      * 子類類靜態(tài)變量
     25:      */
     26:   }
     27: }

     

    但是使用Class.forName 類加載時(shí)就會(huì)完成初始化工作.

      1: public class ClassLoad {
      2:   public static void main(String[] args) throws Exception  {
      3:     /**
      4:      * 使用Class.forName會(huì)自動(dòng)加載所有靜態(tài)區(qū)的信息
      5:      */
      6:     Class son = Class.forName("classLoad.Son");
      7:     Son instance = (Son)son.newInstance();
      8:     /*
      9:      * 執(zhí)行結(jié)果
     10:      * 我在父類靜態(tài)區(qū)里面!父類靜態(tài)變量
     11:      * 我在子類靜態(tài)區(qū)里面!子類類靜態(tài)變量
     12:      * 我在父類構(gòu)造函數(shù)里面!
     13:      * 我在子類構(gòu)造函數(shù)里面!
     14:      */  
     15: 
     16:   }
     17: }
    posted @ 2011-03-13 18:41 小暉 閱讀(885) | 評(píng)論 (0)編輯 收藏

    <2011年3月>
    272812345
    6789101112
    13141516171819
    20212223242526
    272829303112
    3456789

    常用鏈接

    留言簿(2)

    隨筆檔案

    文章分類

    相冊

    最新隨筆

    搜索

    •  

    最新評(píng)論

    閱讀排行榜

    評(píng)論排行榜

    主站蜘蛛池模板: 久久久精品免费视频| 免费在线视频你懂的| 最近免费2019中文字幕大全| 国产精品亚洲视频| 亚洲精品国产成人| 免费不卡在线观看AV| 亚洲熟妇av一区二区三区下载| 日本视频免费在线| 亚洲中文字幕久久无码| 成人免费激情视频| 亚洲国产日韩在线人成下载| 日韩人妻一区二区三区免费 | 搜日本一区二区三区免费高清视频 | 51午夜精品免费视频| 亚洲第一区精品日韩在线播放| 在线观看亚洲精品专区| 日本免费中文字幕在线看| 久久福利青草精品资源站免费| 亚洲色成人网站WWW永久| 9久久免费国产精品特黄| 亚洲精品狼友在线播放| 中文字幕无码一区二区免费| 久久青青成人亚洲精品| 99精品视频免费观看| 一级做a爱过程免费视| 久久亚洲精品AB无码播放| 在线看无码的免费网站| 一级毛片视频免费| 亚洲男同gay片| 亚洲熟女乱综合一区二区 | 亚洲成a人片7777| 青青草国产免费久久久91| 爱情岛亚洲论坛在线观看| 亚洲男女内射在线播放| 免费在线中文日本| 四虎成人精品国产永久免费无码| 亚洲成年网站在线观看| 区三区激情福利综合中文字幕在线一区亚洲视频1 | 6080午夜一级毛片免费看6080夜福利| 亚洲 欧洲 视频 伦小说| 亚洲美女在线观看播放|