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

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

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

    eric-1001c

      BlogJava :: 首頁 :: 新隨筆 :: 聯系 :: 聚合  :: 管理 ::
      3 隨筆 :: 45 文章 :: 12 評論 :: 0 Trackbacks

     

    class Egg{
        
    private Yolk y;
        
    protected class Yolk{
            
    public Yolk(){
                System.out.println(
    "Egg.Yolk()");
            }

        }

        
    public Egg(){
            System.out.println(
    "new Egg()");
            y 
    = new Yolk();
        }

    }

    //bigegg extend egg, and try "override" the yolk
    public class BigEgg extends Egg{
        
    public class Yolk{
            
    public Yolk(){
                System.out.println(
    "BigEgg.Ylok()");    
            }

        }

        
    public static void main(String[] args) {
            
    new BigEgg();
        }

    }

    內部類是一種非常有用的機制,它允許你把一些邏輯相關的類組織在一起,并控制位于內部類的可視性(進入修飾符和其它普通類元素沒有區別)。同時內部類能夠與外部類通信。利用內部類的特性可以使得寫出的代碼優雅而清雅。

    1)內部類可以在內部進行使用,更典型的情況是在外部類設置一個方法返回一個指向內部類的引用
    2)如果想從外部類的非靜態方法之外的任意位置創建某個內部類的對象(這個內部類必須是public),必須具體指明這個對象的類型:OuterClassName.InnerClassName;在new表達式中提供對其它外部類對象的引用,需要使用.new語法。


    OutClass oc 
    = new OutClass();
    OutClass.InnerClass ocic 
    = oc.new InnerClass();

    這個例子也告訴我們,必須使用外部類的對象來創建內部類對象,不能直接創建內部類對象,因為它們之前必須建立一個聯系(當然除了嵌套類--靜態內部類)

    3)內部類和制造它的外圍對象之間有一種聯系(對象創建一個內部類對象時,內部類對象會捕獲一個指向那個外圍類對象的引用),這種聯系使得它能訪問外圍對象的所有成員,而不要任何特殊條件。此外,內部類還擁有其外圍類的所有元素的訪問權。(是不是可以把內部類看成外部類的一個元素,一個“特殊”的“類元素”)
    如果需要生成對外部類對象的引用,可以使用外部類的名字后面緊跟圓點和this“.this”:

    public class Outer{

       
    public class Inner{
       
          
    public Outer getOuter(){
             
    return Outer.this;
          }


    }

    4) 當將內部類向上轉型為其基類,尤其是轉型為一個接口的時候,內部類就有了用武之地。這是因為內部類--某個接口的實現--能夠完全不可見,并且不可用(將內部類進入修飾符設置為private或protected就可以了)。所得到的只是指向基類或接口的引用,所以能夠很方便地隱藏實現細節,也完全阻止任何依賴于類型的編碼
    package chapter10;

    interface Destination{
        String readLabel();
    }

    interface Contents{
        
    int value();
    }

    class OuterInner{
        
    //inner class1
        private class PDestination implements Destination{
            
    private String label;
            
    private PDestination (String whereto){
                label 
    = whereto;
            }

            
    public String readLabel() {
                
    return label;
            }

        }
    ;
        
    //inner class2
        protected class PContents implements Contents{
            
    private int i = 11;
            
    public int value() {
                
    return i;
            }

        }
    ;
        
        
    //method to ge the reference of the inner class pdestination and pcontent
    //    notice that we return a interface instead of the implements of the interface
        public Destination getDestination(String s){
            
    return new PDestination(s);
        }

        
    public Contents getContents(){
            
    return new PContents();
        }

    }


    public class InnerUpcast {

        
    /**
         * 
    @param args
         
    */

        
    public static void main(String[] args) {
            OuterInner oi 
    = new OuterInner();
    //        we also use the interface as the type of the class instead of the inner class type
            Contents c =oi.getContents();
            Destination d 
    = oi.getDestination("Hello");
        }


    5) 同樣的我們可以在任意一個方法中或作用域內創建一個內部類,除了要注意它(內部類)的使用作用域外,其它用法和在類的內部類用法無異。
    6)匿名內部類:沒有名字的,不能有構造器的類
    interface Contents{
        
    int value();
    }

    abstract class Base{
        
    public abstract void f();
    }

    //use anonymous inner class as the vaule of return
    //play your attendtion on that the value of return not only is a inner class
    //but also it will be casted up as a interface, that's the amazing place
    class OuterInner{
    //  use interface as anonymous inner class
        public Contents getContents(){
            
    return new Contents(){
                
    private int i = 11;
                
    public int value() {
                    
    return i;
                }

            }
    ;
        }

    //    use abstract class as anonymous inner class
        public Base getBase(){
            
    return new Base(){
                
    public void f(){
                    
    //do something here
                }

            }
    ;
        }

    }


    public class AnonymousInner {
        
    public static void main(String[] args) {
            OuterInner oi 
    = new OuterInner();
            Contents c 
    =oi.getContents();
            Base b 
    = oi.getBase();
        }

    }
    匿名內部類既可以擴展類(抽象類),也可以實現接口,但不能兩者兼備。如果匿名內部類要使用在其外部定義的對象,則要求該參數引用為final

    7)要創建嵌套類(靜態內部類)意味著:并不需要其外圍類的對象;不能從嵌套類的對象中訪問非靜態的外圍類對象。嵌套類與普通內部類還有一個區別:普通內部類的字段與方法只能放在類的外部層次上,所以普通的內部類不能有static數據和static字段,也不能包含嵌套類。但是嵌套類可以包含所有這些東西。
    8)一個內部類被嵌套多少層并不重要,它能透明地訪問所有它所嵌入的外圍類的所有成員
    9)“每個內部類都能獨立地繼承自一個(接口的)實現,所以無論外圍類是否已經繼承了某個(接口的)實現,對于內部類都沒有影響”,這樣的內部類特性使得其很多解決“多重繼承”:
           a. 內部類可以有多個實例,每個實例都有自己的狀態信息,并且與其外圍類對象的信息相互獨立(通過匿名內部類實現)
           b. 在單個外圍類中,可以讓多個內部類以不同的方式實現同一個接口,或繼承同一個類(通過匿名內部類實現)
           c. 創建內部類對象的時候并不依賴于外圍類對象的創建,并沒有令人迷惑的“is-a”關系,它就是一個獨立的實體

    class PetSequence{
        String[] str 
    =new String[]{"Rat","Manx","Cymric","Mutt","Pug"};
        
    protected ArrayList<String> pets = new ArrayList<String>(
                Arrays.asList(str));
    }


    public class NonClollectionSequence extends PetSequence{
    //    我們在這創建了3個方法,返回類型都是Iterable接口。但不同方法對Iterable接口的實現是不同的
    //    使用匿名內部類很好的以不同的方式實現同一個接口,而且并不依賴于外圍對象
        public Iterable<String> Iterator(){
            
    return new Iterable<String>(){
                
    public Iterator<String> iterator(){
                    
    return new Iterator<String>(){
                        
    private int index = 0;
                        
    public boolean hasNext(){
                            
    return index< pets.size();
                        }

                        
    public String next(){return pets.get(index++);}
                        
    public void remove(){
                            
    throw new UnsupportedOperationException();
                        }

                    }
    ;
                }

            }
    ;
        }

        
        
    public Iterable<String> reversed(){
            
    return new Iterable<String>(){
                
    public Iterator<String> iterator(){
                    
    return new Iterator<String>(){
                        
    private int index = pets.size()-1;
                        
    public boolean hasNext(){
                            
    return index< pets.size();
                        }

                        
    public String next(){
                            
    return pets.get(index--);
                        }

                        
    public void remove(){
                            
    throw new UnsupportedOperationException();
                        }

                    }
    ;
                }

            }
    ;
        }

        
        
    public Iterable<String> randomized(){
            
    return new Iterable<String>(){
                
    public Iterator<String> iterator(){
                    List
    <String> shuffed = new ArrayList<String>(Arrays.asList(str));
                    Collections.shuffle(shuffed, 
    new Random(47));
                    
    return shuffed.iterator();
                }

            }
    ;
        }


        
    public static void main(String[] args) {
            NonClollectionSequence s 
    = new NonClollectionSequence();
            
    for(String string: s.reversed())
                System.out.println(string);
            System.out.println();
            
    for(String string2: s.randomized())
                System.out.println(string2);
        }

    }

    10)如果創建一個繼承具有內部類的外圍類的新類,并在新類中試圖覆蓋內部類,會發生什么呢?

    當繼承了某個外圍類的時候,內部類并沒有發生什么特別的神奇的變化。這兩個內部類是完全獨立的兩個實體,各自在自己的命名空間內
    11)內部類的標識符:外圍類的名字,加上‘$’,再加上內部類的名字,比如OuterClass$InnerClass;對了匿名內部類,編譯器會簡單地產生一個數字作為其標識符,比如OuterClass$1
    12)局部內部類VS匿名內部類
          a. 局部內部類可以提供一個構造器,方便重載構造器,而匿名內部類只能用于實例初始化
          b. 局部內部類可以被使用多次,然而匿名內部類只能實例化一次
    posted on 2007-07-17 11:18 Eric-1001c 閱讀(223) 評論(0)  編輯  收藏 所屬分類: ThinkingInJava
    主站蜘蛛池模板: 国产精品亚洲天堂| AV大片在线无码永久免费| 亚洲人成网站色在线观看| 国产精品亚洲а∨无码播放| 歪歪漫画在线观看官网免费阅读| 中国极品美軳免费观看| 男男黄GAY片免费网站WWW| 亚洲综合中文字幕无线码| 亚洲第一精品福利| 中文字幕一精品亚洲无线一区| 国产美女a做受大片免费| 成人无码区免费视频观看| 在线看无码的免费网站| 国产午夜精品久久久久免费视| 猫咪www免费人成网站| 亚洲大码熟女在线观看| 亚洲中文字幕无码久久2020| 亚洲神级电影国语版| 婷婷精品国产亚洲AV麻豆不片| 亚洲中文字幕无码一区二区三区| 亚洲av无码成人精品区| 在线看片人成视频免费无遮挡| 中文字幕无码视频手机免费看| 1000部拍拍拍18免费网站| 久久久久久国产精品免费无码| 永久在线观看免费视频| 中文字幕av无码不卡免费| 丰满人妻一区二区三区免费视频 | 99久久久精品免费观看国产| a视频免费在线观看| 中文字幕视频在线免费观看| eeuss免费天堂影院| 国产精品免费久久| 中文字幕一区二区免费| 久久大香伊焦在人线免费| 免费国产成人α片| 午夜免费福利小电影| 99re免费在线视频| 69堂人成无码免费视频果冻传媒| 国产桃色在线成免费视频| 国产精品无码免费播放|