• <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>

            C++研究

            C++細(xì)節(jié)深度探索及軟件工程

              C++博客 :: 首頁 :: 新隨筆 :: 聯(lián)系 :: 聚合  :: 管理 ::
              37 隨筆 :: 0 文章 :: 74 評論 :: 0 Trackbacks

             嵌套類的訪問問題:

            記得白鳳煮的C++中有一句這樣的話:C++嵌套類只是語法上的嵌套。然而在實(shí)踐過程中,卻并非如此。
            Ex:

            class A
            {
            public:  
                
            static int a;
                
            class A1
                
            {
                    
            void output()
                    
            {
                      cout
            <<a<<endl; //instead of A::a;
                    }

                }
            ;
              
            }
            ;
            int A::a;


            可見,類 A1 嵌入A后訪問A的靜態(tài)變量不寫外圍域沒有任何問題,從編譯的角度看,此時位于A::的作用域內(nèi),在符號表中是可以找到a的(注意,a必須為static的)。這一點(diǎn),與分開寫的兩個類明顯不同

            天津大學(xué)計算機(jī)學(xué)院 常興龍 MSN: cxl82116@msn.com

            還有一個特殊之處,見如下代碼:

             

            Ex:

            class A
            {
            private:
                
            int a;
                
            class A1
                
            {
                    
            void output(A aObject)
                    
            {
                      cout
            <<aObject.a<<endl; //instead of A::a;
                    }

                }
            ;
              
            }
            ;





            這段代碼在VC中不能編譯通過,但在DEV-C++是可以的,也就是不同的編譯對于嵌套類是否能訪問外圍類的私有成員的定義是不一致的。

            嵌套類的不同作用域同名問題:

            class A
            {
            public:  
                
            static int a;
                
            class A1
                
            {
                    
            static int a;
                    
            int    void output()
                    
            {
                      cout
            <<a<<endl; //instead of A::a;
                    }

                }
            ;
              
            }
            ;
            int A::a=3;
            int A::A1::a=4;


            輸出內(nèi)部的a沒有問題,如果要訪問外部的,使用A::a指明作用域就可以,而且在嵌套類中,可以定義靜態(tài)的成員。
            用類似A::A1::a就可以訪問.
            先看一下Java的情況
            Ex:

            //this is a Java class 
            class A
            {
                
            private int c=2;
                
            class A1
                
            {
                    
            int c=3;
                    
            void output()
                    
            {
                        System.
            out.println(this.c);
                        System.
            out.println(A.this.c);
                    }

                }

            }



            由定義就可看出,Java的定義是動態(tài)定義的,是基于this指針的,因此,嵌套類不只在語法上,在語義上也有隸屬關(guān)系,外圍類的成員,包含私有成員,對于內(nèi)部類也是可見的。因此內(nèi)部非Static的類不能有Static成員,且這樣的內(nèi)部類只有在外層的對象建立后才能對建立,所以你可以這么建立對象:
            Ex:

             A a = new A();
             A.A1 aa = a.new A1();

            或者:
            Ex:
             
            A.A1 aa = new A().new A1(); //使用匿名對象

            如果是靜態(tài)嵌套類
            Ex:

             


            //this is a Java class 
            class A
            {
                
            private int c=2//(1)
                static class A1
                
            {
                  
            static int c=3;
                    
            void output()
                    
            {
                        
            //System.out.println(this.c); //work well <--> A.A1.c; 這個結(jié)果由編譯靜態(tài)成生和動態(tài)加載相對地址理論輕松解釋
                        
            //System.out.println(A.this.c);// (can't work) ,很明顯要求外圍對象存在,把(1)改成static 的可以通過
                        System.out.println(c);  //work well 
                    }

                }

            }



            對比上面Java的定義,可見C++中的黓認(rèn)行為和Java中的靜態(tài)類相似,由此,可以猜出C++中的類是做靜態(tài)存儲的。因此,可以輕松的得出如下語句也是可以的:


            Ex:
            //C++
            A::A1 * a = new A::A1();

             

            因此,也可以得到在 C++ 中 ,內(nèi)部類也是可以有靜態(tài)對象的。

            posted on 2007-05-23 02:23 常興龍 閱讀(7808) 評論(3)  編輯 收藏 引用

            評論

            # re: 有關(guān) C++ 嵌套類 2007-05-23 06:50 飯中淹
            試試便知。

            我以前看過書上說類中類算是友元類,不應(yīng)該能訪問私有,可以訪問保護(hù)。  回復(fù)  更多評論
              

            # re: 有關(guān) C++ 嵌套類 2007-06-10 17:46 黃大仙
            好  回復(fù)  更多評論
              

            # re: 有關(guān) C++ 嵌套類 2008-10-05 14:57 老穆
            好!!  回復(fù)  更多評論
              


            只有注冊用戶登錄后才能發(fā)表評論。
            網(wǎng)站導(dǎo)航: 博客園   IT新聞   BlogJava   博問   Chat2DB   管理


            > hi的博客
            99久久99久久精品国产片果冻| 国产福利电影一区二区三区久久老子无码午夜伦不 | 久久久精品国产| 91久久香蕉国产熟女线看| 国内精品久久久久影院优| 亚洲精品乱码久久久久久蜜桃不卡 | 蜜臀久久99精品久久久久久| 99久久伊人精品综合观看| 99久久中文字幕| 好久久免费视频高清| 久久99精品久久只有精品| 欧洲成人午夜精品无码区久久| 久久青青草原亚洲av无码app| 亚洲精品无码久久毛片| 亚洲欧美一区二区三区久久| 亚洲欧美成人久久综合中文网| 三级韩国一区久久二区综合| 7777精品伊人久久久大香线蕉| 久久亚洲中文字幕精品一区| 亚洲精品NV久久久久久久久久| 大香伊人久久精品一区二区| 久久热这里只有精品在线观看| 免费久久人人爽人人爽av| 狠狠色婷婷久久一区二区| 99久久精品免费看国产一区二区三区 | 中文精品99久久国产| 久久精品国产亚洲AV不卡| 久久综合给合久久国产免费| 久久99免费视频| 国产精品99久久久久久猫咪| 人妻无码精品久久亚瑟影视| 久久精品国产亚洲AV影院| 久久精品人人槡人妻人人玩AV| 国产精品久久久久久一区二区三区 | 婷婷久久五月天| 青青草原精品99久久精品66| 国产精品9999久久久久| 99久久国产综合精品成人影院| 久久久久久亚洲精品不卡| 无码AV波多野结衣久久| 精品多毛少妇人妻AV免费久久|