• <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>
            酸菜豬蹄的程序人生
            木下編程屯屯燙燙
               什么時(shí)候調(diào)用拷貝構(gòu)造函數(shù)?什么時(shí)候調(diào)用賦值運(yùn)算符?

                很多初學(xué)者容易搞不清楚。我來總結(jié)一下就是:

                當(dāng)進(jìn)行一個(gè)類的實(shí)例初始化的時(shí)候,也就是構(gòu)造的時(shí)候,調(diào)用的是構(gòu)造函數(shù)(如是用其他實(shí)例來初始化,則調(diào)用拷貝構(gòu)造函數(shù)),非初始化的時(shí)候?qū)@個(gè)實(shí)例進(jìn)行賦值調(diào)用的是賦值運(yùn)算符。

                示例如下:

             1 #include <iostream>
             2 using namespace std;
             3 /************************************************************************/
             4 /* 該例子用來說明copy constructor 和 賦值運(yùn)算符的調(diào)用情況                      */
             5 /************************************************************************/
             6 class CTest
             7 {
             8 public:
             9     int m_muber;
            10     CTest():m_muber(0)
            11     {
            12         cout << "CTest()" << endl;
            13     }
            14     CTest(const CTest& t)
            15     {
            16         cout << "CTest(const CTest& t)" << endl;
            17         this->m_muber = t.m_muber;
            18     }
            19     CTest(const int& t)
            20     {
            21         cout << "CTest(const int& t)" << endl;
            22         this->m_muber = t;
            23     }
            24     CTest& operator=(const CTest& t)
            25     {
            26         cout << "CTest& operator=(const CTest& t)" << endl;
            27         this->m_muber = t.m_muber;
            28         return *this;
            29     }
            30     CTest& operator=(const int& t)
            31     {
            32         cout << "CTest& operator=(const int& t)" << endl;
            33         this->m_muber = t;
            34         return *this;
            35     }
            36 
            37 
            38 };
            39 int main()
            40 {
            41     cout << "*********CTest a****************" << endl;
            42     CTest a;
            43     cout << "*********CTest b(a)*************" << endl;
            44     CTest b(a);
            45     cout << "*********CTest c = a ***********" << endl;
            46     CTest c = a;
            47     cout << "*********CTest d = 5************" << endl;
            48     CTest d = 5;
            49 
            50     cout << "*********b = a************" << endl;
            51     b = a;
            52     cout << "*********c = 5************" << endl;
            53     c = 5;
            54 
            55     return 0;
            56 }
            57 

                例子中執(zhí)行結(jié)果是:
            *********CTest a****************
            CTest()

            *********CTest b(a)*************
            CTest(const CTest& t)

            *********CTest c = a ***********
            CTest(const CTest& t)

            *********CTest d = 5************
            CTest(const int& t)

            *********b = a************
            ******
            CTest& operator=(const CTest& t)

            *********c = 5************
            ******
            CTest& operator=(const int& t)

             
            posted on 2006-05-15 09:54 cooelaf 閱讀(1146) 評(píng)論(4)  編輯 收藏 引用 所屬分類: Pure C/C++
            Comments
            • # re: 關(guān)于拷貝構(gòu)造函數(shù)和賦值運(yùn)算符
              <font color="#FF00FF" >Stone Jiang
              Posted @ 2006-05-15 10:31
              這個(gè)示例不錯(cuò),區(qū)分出了拷貝構(gòu)造函數(shù)和賦值函數(shù).

              有一個(gè)問題及建議
              C++類設(shè)計(jì)中,最重要的四個(gè)函數(shù)則(Big Four Function)是
              構(gòu)造函數(shù),析構(gòu)函數(shù),拷貝構(gòu)造函數(shù)和賦值函數(shù),博主是否在本文中,沒有正確的把構(gòu)造函數(shù)和拷貝構(gòu)造函數(shù)區(qū)分開來?
              CTest a;

              *********CTest a****************
              CTest()

              調(diào)用的應(yīng)該叫"構(gòu)造函數(shù)"而不是"拷貝構(gòu)造函數(shù)"


              CTest b(a);

              CTest b = a 應(yīng)是等價(jià)的,均調(diào)用
              "拷貝構(gòu)造函數(shù)"

              建議:博主同時(shí)闡述C++類設(shè)計(jì)中的 Big Four Function.

                回復(fù)  更多評(píng)論   
            • # re: 關(guān)于拷貝構(gòu)造函數(shù)和賦值運(yùn)算符
              CoderDream
              Posted @ 2006-05-15 10:34
              41 cout << "*********CTest a****************" << endl;
              42 CTest a; // 調(diào)用默認(rèn)構(gòu)造函數(shù)
              43 cout << "*********CTest b(a)*************" << endl;
              44 CTest b(a); // 調(diào)用拷貝構(gòu)造函數(shù)
              45 cout << "*********CTest c = a ***********" << endl;
              46 CTest c = a; // 調(diào)用拷貝構(gòu)造函數(shù)
              47 cout << "*********CTest d = 5************" << endl;
              48 CTest d = 5; // 調(diào)用拷貝構(gòu)造函數(shù),參數(shù)為int 型,會(huì)進(jìn)行類型轉(zhuǎn)換:
              49
              50 cout << "*********b = a************" << endl;
              51 b = a; // 調(diào)用重載操縱符=
              52 cout << "*********c = 5************" << endl;
              53 c = 5; // 調(diào)用重載操縱符=,參數(shù)為int 型,會(huì)進(jìn)行類型轉(zhuǎn)換:
                回復(fù)  更多評(píng)論   
            • # re: 關(guān)于拷貝構(gòu)造函數(shù)和賦值運(yùn)算符
              cooelaf
              Posted @ 2006-05-15 10:41
              @&lt;font color=&quot;#FF00FF&quot; &gt;Stone Jiang


              嗯,我這里主要是想說明拷貝構(gòu)造函數(shù)和賦值運(yùn)算符的區(qū)別。所以沒放在一般構(gòu)造函數(shù)和拷貝構(gòu)造函數(shù)上。希望不要誤導(dǎo)了別人:)  回復(fù)  更多評(píng)論   
            • # re: 關(guān)于拷貝構(gòu)造函數(shù)和賦值運(yùn)算符
              lijun
              Posted @ 2006-05-15 14:11
              無意中找到你的博客了,本來是想找找:一個(gè)類在什么情況下 必須 寫拷貝構(gòu)造函數(shù),在什么情況下可以不用寫(即調(diào)用默認(rèn)的拷貝構(gòu)造函數(shù)).
              必須就是如果你沒有寫,程序在調(diào)用了拷貝構(gòu)造函數(shù)后,就會(huì)出錯(cuò)!
              不用寫就是,程序在調(diào)用了默認(rèn)拷貝構(gòu)造函數(shù)后,是正常的.
              其實(shí)這個(gè)問題很簡(jiǎn)單回答的.但是是怎樣的情況使我想起到這里的呢!
              vector<Csocket> VECTOR;
              VECTOR m_SocketVector;
              ...
              接收ClientSocket函數(shù):
              {
              Csocket sock;
              sock.m_hSock = accept(m_ServerSocket.m_hSocket,...
              m_SocketVector.push_back(sock);
              }
              這是必然調(diào)用拷貝構(gòu)造函數(shù),想想效果怎樣!?
              當(dāng)然上面的可以這樣寫:
              vector<Csocket*> VECTOR;
              VECTOR m_SocketVector;
              接收ClientSocket函數(shù):
              {
              Csocket sock = new Csocket;
              sock->m_hSock = accept(m_ServerSocket.m_hSocket,...
              m_SocketVector.push_back(&sock);
              }
              那個(gè)更好呢?
              有一個(gè)假設(shè),本程序?qū)崿F(xiàn)的是短連接,會(huì)有不斷的Socket連接,斷開.
              當(dāng)然斷開時(shí)是會(huì)調(diào)用delete的. 也就說白了,用new程序會(huì)不斷的申請(qǐng)堆空間,再不斷的釋放空間.這樣作為一個(gè)服務(wù)器來說,時(shí)間長(zhǎng)了會(huì)有堆的內(nèi)存碎片,程序運(yùn)行會(huì)變慢??但是用vector 系統(tǒng)會(huì)處理內(nèi)存碎片的處理的(聽說的) ??!
              考慮這個(gè)原因,將要怎樣處理??
              但是用上一種方法的話,系統(tǒng)會(huì)不斷的調(diào)用拷貝一個(gè)對(duì)象,再析構(gòu)調(diào)那個(gè)臨時(shí)對(duì)象.也是影響了效率!!??

                回復(fù)  更多評(píng)論   
             
            久久精品国产亚洲av麻豆色欲| 国产成人精品久久综合| 亚洲精品国产综合久久一线| 久久精品国产2020| 久久综合亚洲欧美成人| 国内精品久久久久久久亚洲| 99久久精品国产一区二区| 狠狠色丁香久久综合五月| 久久久久亚洲精品天堂久久久久久| 国内精品久久久久影院亚洲| 久久精品视频免费| 思思久久99热只有频精品66| 久久中文娱乐网| 久久亚洲精精品中文字幕| 久久亚洲中文字幕精品一区四| 东京热TOKYO综合久久精品 | AV狠狠色丁香婷婷综合久久| 久久99国产精品成人欧美| 国内精品久久人妻互换| 热久久视久久精品18| 精品一久久香蕉国产线看播放| 午夜天堂精品久久久久| 欧美久久久久久| 久久无码一区二区三区少妇| 亚洲国产精品一区二区久久| 久久综合给久久狠狠97色| 午夜精品久久久久| 亚洲成av人片不卡无码久久| 久久国产成人午夜aⅴ影院| 久久精品国产91久久综合麻豆自制 | 久久91精品国产91久久麻豆 | 久久国产精品久久精品国产| 久久精品国产精品亚洲毛片| 日本强好片久久久久久AAA| 久久精品日日躁夜夜躁欧美| 久久久久久久久波多野高潮| 国产69精品久久久久9999APGF| 久久婷婷五月综合97色直播| 97精品依人久久久大香线蕉97| 久久精品国产亚洲AV久| 久久夜色精品国产网站|