• <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>
            隨筆 - 74, 文章 - 0, 評論 - 26, 引用 - 0
            數據加載中……

            C++類對象的拷貝構造函數分析

            對于普通類型的對象來說,它們之間的復制是很簡單的,例如:

            int a=100;
            int b=a;

              而類對象與普通對象不同,類對象內部結構一般較為復雜,存在各種成員變量。下面看一個類對象拷貝的簡單例子。

            #include <iostream>
            using namespace std;
            class CA
            {
             public:
              CA(int b)
              {
               a=b;
              }
              void Show ()
              {
               cout<<a<<endl;
              }
             private:
              int a;
            };

            int main()
            {
             CA A(100);
             CA B=A;
             B.Show ();
             return 0;
            }

              運行程序,屏幕輸出100。從以上代碼的運行結果可以看出,系統為對象B分配了內存并完成了與對象A的復制過程。就類對象而言,相同類型的類對象是通過拷貝構造函數來完成整個復制過程的。下面我們舉例說明拷貝構造函數的工作過程。

            #include <iostream>
            using namespace std;
            class CA
            {
             public:
              CA(int b)
              {
               a=b;
              }
              CA(const CA& C)
              {
               a=C.a;
              }
              void Show()
              {
               cout<<a<<endl;
              }
             private:
              int a;
            };

            int main()
            {
             CA A(100);
             CA B=A;
             B.Show ();
             return 0;
            }

              CA(const CA& C)就是我們自定義的拷貝構造函數??梢?,拷貝構造函數是一種特殊的構造函數,函數的名稱必須和類名稱一致,它的唯一的一個參數是本類型的一個引用變量,該參數是const類型,不可變的。例如:類X的拷貝構造函數的形式為X(X& x)。

              當用一個已初始化過了的自定義類類型對象去初始化另一個新構造的對象的時候,拷貝構造函數就會被自動調用。也就是說,當類的對象需要拷貝時,拷貝構造函數將會被調用。以下情況都會調用拷貝構造函數:

              一個對象以值傳遞的方式傳入函數體

              一個對象以值傳遞的方式從函數返回

              一個對象需要通過另外一個對象進行初始化。

              如果在類中沒有顯式地聲明一個拷貝構造函數,那么,編譯器將會自動生成一個默認的拷貝構造函數,該構造函數完成對象之間的位拷貝。位拷貝又稱淺拷貝,后面將進行說明。

              自定義拷貝構造函數是一種良好的編程風格,它可以阻止編譯器形成默認的拷貝構造函數,提高源碼效率。

              淺拷貝和深拷貝

              在某些狀況下,類內成員變量需要動態開辟堆內存,如果實行位拷貝,也就是把對象里的值完全復制給另一個對象,如A=B。這時,如果B中有一個成員變量指針已經申請了內存,那A中的那個成員變量也指向同一塊內存。這就出現了問題:當B把內存釋放了(如:析構),這時A內的指針就是野指針了,出現運行錯誤。

              深拷貝和淺拷貝可以簡單理解為:如果一個類擁有資源,當這個類的對象發生復制過程的時候,資源重新分配,這個過程就是深拷貝,反之,沒有重新分配資源,就是淺拷貝。下面舉個深拷貝的例子。

            #include <iostream>
            using namespace std;
            class CA
            {
             public:
              CA(int b,char* cstr)
              {
               a=b;
               str=new char[b];
               strcpy(str,cstr);
              }
              CA(const CA& C)
              {
               a=C.a;
               str=new char[a]; //深拷貝
               if(str!=0)
                strcpy(str,C.str);
              }
              void Show()
              {
               cout<<str<<endl;
              }
              ~CA()
              {
               delete str;
              }
             private:
              int a;
              char *str;
            };

            int main()
            {
             CA A(10,"Hello!");
             CA B=A;
             B.Show();
             return 0;
            }

              好吧,就說這些,希望本文能對您有所幫助。

            posted on 2006-12-01 08:52 井泉 閱讀(216) 評論(0)  編輯 收藏 引用 所屬分類: C++

            国内精品久久久久影院网站| 亚洲欧洲精品成人久久奇米网| 午夜精品久久久内射近拍高清 | 久久久久AV综合网成人| 久久久无码一区二区三区| 久久九九有精品国产23百花影院| 久久亚洲高清综合| 无码人妻久久一区二区三区| 蜜桃麻豆www久久| 久久亚洲sm情趣捆绑调教| 国产成人久久激情91| 亚洲精品成人久久久| 国产精品免费看久久久| 中文成人无码精品久久久不卡| 久久99国产精品尤物| 色欲综合久久躁天天躁| 久久精品毛片免费观看| 久久久久国产精品人妻| 国产精品热久久无码av| 久久久久久久综合日本亚洲| 囯产极品美女高潮无套久久久| 国产精品久久久99| 久久96国产精品久久久| 欧美熟妇另类久久久久久不卡| 亚洲综合久久夜AV | 精品久久久久久无码人妻热| 久久夜色精品国产亚洲| 色8久久人人97超碰香蕉987| 久久综合偷偷噜噜噜色| 人人狠狠综合88综合久久| 久久国产精品免费一区二区三区| 1000部精品久久久久久久久| 色88久久久久高潮综合影院| 色偷偷88888欧美精品久久久 | 一级做a爰片久久毛片免费陪| 999久久久无码国产精品| 久久亚洲美女精品国产精品| 亚洲日本va中文字幕久久| 中文字幕日本人妻久久久免费| 久久91精品国产91| 人人妻久久人人澡人人爽人人精品 |