什么是靜態(tài)內(nèi)部(Static Inner)類,語法要注意什么

靜態(tài)內(nèi)部類(Static Inner Classes)
馬克- to-win:馬克 java社區(qū):防盜版實名手機尾號: 73203。
馬克-to-win:這里的內(nèi)部類的static,意思是它可以不用實例化外部類,就自己單獨被實例化,單獨存在(有點像生活中的辦公室和辦公桌(獨立于辦公室,辦公桌也可以存在)),靜態(tài)方法不就不用實例化類,直接用嗎?就實例化而言,靜態(tài)內(nèi)部類和外層類之間完全沒有任何關系,相互獨立。誰愛怎么樣,就怎么樣!誰想實例化誰就實例化,不管對方的感受。當然要想讓它們有關系,也可以,見下面例子中的tc.core=nc;
重要語法:馬克-to-win:1)靜態(tài)內(nèi)部類里的任何方法(靜態(tài)或非靜態(tài))不允許訪問外層類里的實例屬性或方法。(因為外層類本身可能沒有被實例化),想訪問通過下面例子中的tc.core=nc。2)靜態(tài)屬性和方法無論在外層類還是靜態(tài)內(nèi)部類, 都可以被任意調(diào)用(對方或自己或測試類)。



例2.4
class ShellMark_to_win {
    static  int ss_i ;
    private int si_k;
    Core core;
    static class Core {
        static  int cs_m ;
        int ci_j;
        public Core(int j) {
            ss_i = 2;//可以直接訪問外層類的靜態(tài)域
            cs_m=3;
            //k=9;//馬克-to-win:compile error,static class can not refer to a non-static field,因為靜態(tài)內(nèi)部類可以脫離外層實例而單獨存在,靜態(tài)內(nèi)部類可能已經(jīng)被實例化,而外層類沒有被實例化,外層的實例變量就不能被訪問。像原來的靜態(tài)方法似的,不能訪問實例變量
            this.ci_j = j;
        }
        public String toString()
        {
            //ShellMark_to_win.changTopValue();//可以訪問外層類的靜態(tài)方法
            //insMethod();//不能從靜態(tài)類里訪問外層類的實例方法。
            return "ci_j=" + ci_j + ";ss_i=" + ss_i+" ;cs_m="+cs_m;// 馬克-to-win:這里不能寫+k,因為cocs_mpile error,static class can not refer to a non-static field,像原來的靜態(tài)方法似的,不能訪問實例變量
        }
        static int changValue()
        {   //inscs_method();//不能從靜態(tài)類里訪問實例方法。
            cs_m=cs_m+2;
            ss_i=ss_i+2;
            //k=9;//馬克-to-win:這里不能寫+k,因為compile error,static class can not refer to a non-static field,像原來的靜態(tài)方法似的,不能訪問實例變量
          //  ShellMark_to_win.changTopValue();完全可以調(diào)用
            System.out.println("cs_m is "+cs_m+" ss_i is"+ss_i);
            //ci_j=ci_j+2;//錯誤, 靜態(tài)方法無法訪問非靜態(tài)變量
            return cs_m;
        }
    }
    public String toString() {
        //Core.changValue();//可以訪問靜態(tài)內(nèi)部類的靜態(tài)方法   
        return "si_k=" + si_k + ";ss_i=" + ss_i+"cs_m is "+Core.cs_m;
    }
    void insMethod()
    {
   
    }
    static int changTopValue()
    {
        ShellMark_to_win.Core.cs_m=ShellMark_to_win.Core.cs_m+2;
        ss_i=ss_i+2;
        return ss_i;
    }
}
public class Test {
    public static void main(String[] args) {
        System.out.println(ShellMark_to_win.ss_i+" "+ShellMark_to_win.Core.cs_m);
        System.out.println(ShellMark_to_win.changTopValue());
        System.out.println(ShellMark_to_win.Core.changValue());
        ShellMark_to_win tc = new ShellMark_to_win();
        System.out.println("tc is "+tc);
/* 馬克-to-win:since Core is static member, we can use in this way.不用實例化外部類, 就可以單獨存在 */
        ShellMark_to_win.Core nc = new ShellMark_to_win.Core(5);
/*加上下面兩句話,可以讓外層類和內(nèi)部類產(chǎn)生聯(lián)系而且相互改值*/     
   //     tc.core=nc;
   //     tc.core.ci_j=100;
        System.out.println("nc is "+nc);
        nc.changValue();
        System.out.println("tc is "+tc);
    }
}




rsult is:
0 0
2
cs_m is 4 ss_i is4
4
tc is si_k=0;ss_i=4cs_m is 4
nc is ci_j=5;ss_i=2 ;cs_m=3
cs_m is 5 ss_i is4
tc is si_k=0;ss_i=4cs_m is 5