• <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>
            posts - 195,  comments - 30,  trackbacks - 0

            原文地址:http://blog.csdn.net/yiyunoo/archive/2008/05/16/2452363.aspx

            c++構造函數后面的冒號
            初始化列表,跟在{}里面的初始化沒有什么不同,但在非靜態const類型以及引用型成員變量必須在初始化列表里面初始化,不能在{}里面初始化.A(b)就是用父類的構造函數進行一部分初始化.
            --------------

            很多的人對中構造函數寢初始化很多的困惑,對冒號后初始化不是太明白,總搞不清楚它們之間的區別,我想把我對這個問題的理解和看法和大家討論討論。

               在程序中定義變量并初始化的機制中,有兩種形式,一個是我們傳統的初始化的形式,即賦值運算符賦值,還有一種是括號賦值,如:
               int a=10;
               char b='r';\\賦值運算符賦值
              int a(10);\
               char b('r');\\括號賦值
            以上定義并初始化的形式是正確的,可以通過編譯,但括號賦值只能在變量定義并初始化中,不能用在變量定義后再賦值,這是和賦值運算符賦值的不同之處,如:
               (1)
               int a;  \\先定義一個變量
               ......
               a=10;  \\根據需要賦值

               (2)
               int b;   \\先定義一個變量
               ......
               b(10);  \\和(1)一樣根據需要賦值
            (1)是可以用通過編譯,定義一個變量a但并沒有初始化,在需要變量a的時候,通過賦值運算符把10賦給a,而在(2)中,是通過括號把10賦值給b,但編譯系統認為
            這是一個函數的調用,函數名為b,10為實際參數,所以編譯錯誤。因此,括號賦值只用在定義變量并初始化中。 
                現在我們來看構造函數中冒號初始化和函數初始化的問題,類構造函數的作用是創建一個類的對象時,調用它來構造這個類對象的數據成員,一要給出此數據成員分配內存空間,二是要給函數數據成員初始化,構造數據成員是按數據成員在類中聲明的順序進行構造。

                冒號初始化與函數體初始化的區別在于:

               冒號初始化是給數據成員分配內存空間時就進行初始化,就是說分配一個數據成員只要冒號后有此數據成員的賦值表達式(此表達式必須是括號賦值表達式),那么分配了內存空間后在進入函數體之前給數據成員賦值,就是說初始化這個數據成員此時函數體還未執行。

                對于在函數中初始化,是在所有的數據成員被分配內存空間后才進行的。

               這樣是有好處的,有的數據成員需要在構造函數調入之后函數體執行之前就進行初始化如引用數據成員,常量數據成員對象數據成員,看下面的一段程序:
               class student
               {public :

                 student ()
                  .
                  .
                  .
                 protected:
                 const int a;
                 int &b; 
               }

               student ::student (int i,int j)
              {
                 a=i;
                 b=j;
               }

            在Student類中有兩個數據成員,一個是常量數據成員,一個是引用數據成員,并且在構造函數中初始化了這兩個數據成員,但是這并不能通過編譯,因為常量初始化時必須賦值,它的值是不能再改變的,與常量一樣引用初始化也需要賦值,定義了引用后,它就和引用的目標維系在了一起,也是不能再被賦值的。所以C ++":"后初始化的機制,使引用和常量數據成員變為可能的,Student類的構造函數應為:
                student ::student(int i,int j):a(i),b(j){}

            在下面的程序:
                class teach
               { 
                public :
                  teach(char *p="name",int a=0)
                       .         .
                       .
                protected:
                  char name[30];
                  int age;
               }
               teach ::teach(char*p,int a)
               {
                strcopy(name ,p);
                age=a;    
                     cout>>name>>endl;
               }
               class student
              {
                public:
                 student (char *p="name");
                       .
                       .
                       .
                protected;
                 char name[30];
                 teach teacher;
               };
               student::student(char *p)
               {
                 strcopy(name,p);
                 cont>>name>>endl;
               }
            在上面的程序中通不過編譯,編譯系統會告訴你teacher這個類對象缺默認構造函數,因為在teach 類中沒有定義默認的構造函數。那么帶參數的構造函數怎么進行構造呢?通過我們前面提到的冒號賦值。那它的構造函數應該是:
               
               student::student(char *p,char *pl,int ag):teacher(pl,ag)
               {
                 strcopy(name,p);
                 cont>>name>>endl;
               }
            就是說在沒有默認構造函數的時候,如果一個類對象是另一個類的數據成員,那么初始化這個數據成員,就應該放到冒號后面。這樣可以帶參數。在類的定義中,如: 
                 protected;
                 char name[30];
                 teach teacher
            類對象是不能帶參數的,因為它只是聲明。

                所以在C++中就增加了這種機制,這是面向對象編程所必須的。不知道我講明白沒有。如不明白請查閱有關資料

            posted on 2011-02-14 21:40 luis 閱讀(7320) 評論(2)  編輯 收藏 引用

            FeedBack:
            # re: C++構造函數中的初始化:C++構造函數后面的冒號
            2013-01-23 02:25 | 老岳
            講的非常好。很有條例,也很簡潔。贊!  回復  更多評論
              
            # re: C++構造函數中的初始化:C++構造函數后面的冒號[未登錄]
            2013-10-04 20:10 | summer
            最后學生老師那段代碼是可以編譯通過運行的啊,文中的代碼你都嘗試編譯過了嗎?  回復  更多評論
              
            <2012年10月>
            30123456
            78910111213
            14151617181920
            21222324252627
            28293031123
            45678910

            常用鏈接

            留言簿(3)

            隨筆分類

            隨筆檔案

            文章分類

            文章檔案

            友情鏈接

            搜索

            •  

            最新評論

            閱讀排行榜

            評論排行榜

            久久久久国产一级毛片高清板| 亚洲AV无码久久| 久久久久久亚洲精品无码| 久久久噜噜噜久久| 久久九九久精品国产免费直播| 无遮挡粉嫩小泬久久久久久久| 精品国产乱码久久久久久1区2区 | 久久精品99久久香蕉国产色戒| 精品少妇人妻av无码久久| 精品久久久久久久久久中文字幕 | 色综合久久88色综合天天 | 久久久久99这里有精品10| 久久99国产精品尤物| 欧美大战日韩91综合一区婷婷久久青草 | 日韩乱码人妻无码中文字幕久久 | 色综合久久久久综合99| 久久精品无码专区免费青青| 久久久久亚洲av成人无码电影| 久久精品国产亚洲AV高清热| 亚洲精品国精品久久99热| 久久99精品综合国产首页| 亚洲AV成人无码久久精品老人| 午夜视频久久久久一区 | 欧美综合天天夜夜久久| 久久久久久精品免费免费自慰| 国产高潮国产高潮久久久91| 国产精品久久亚洲不卡动漫| 麻豆精品久久久久久久99蜜桃 | 人妻无码精品久久亚瑟影视 | 99久久久精品| 色婷婷综合久久久久中文| 伊人久久大香线蕉综合热线| 国产精品热久久无码av| 国产一级持黄大片99久久| 精品久久久久久| 久久久久久久综合日本亚洲| MM131亚洲国产美女久久| 久久精品国产亚洲77777| 伊人久久久AV老熟妇色| 欧美日韩精品久久久免费观看| 伊人色综合九久久天天蜜桃|