青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品

woaidongmao

文章均收錄自他人博客,但不喜標題前加-[轉貼],因其丑陋,見諒!~
隨筆 - 1469, 文章 - 0, 評論 - 661, 引用 - 0
數據加載中……

編譯器為類構建那些默認函數?

一個空類什么時候不是空類?   ----   C++編譯器通過它的時候。如果你沒有聲明下列函數,體貼的編譯器會聲明它自己的版本。這些函數是:一個拷貝構造函數,一個賦值運算符,一個析構函數,一對取址運算符,一個缺省構造函數。所有這些函數都是公有的。換句話說,如果你這么寫: 
  class   Empty{};  
 
和你這么寫是一樣的:    
  

1.       class   Empty   {   

2.         public:   

3.             Empty();    //   缺省構造函數   

4.             Empty(const   Empty&   rhs);     //   拷貝構造函數      

5.             ~Empty();        //   析構函數   ----   是否 為虛函數看下文說明 

6.             Empty&  operator=(const   Empty&   rhs);         //   賦值運算符       

7.             Empty*   operator&();                           //   取址運算符   

8.             const   Empty*   operator&()   const;   

9.         };   

10.    

11.    

  
 
現在,如果需要,這些函數就會被生成,但你會很容易就需要它們。下面的代碼將使得每個函數被生成:  
   
  const   Empty   e1;                       //  
缺省構造函數  
  Empty   e2(e1);                           //  
拷貝構造函數  
  e2   =   e1;                                 //  
賦值運算符
  Empty   *pe2   =   &e2;               //   取址運算符    (const)      
  const   Empty   *pe1   =   &e1;    //    
取址運算符    (const)  
   
 
假設編譯器為你寫了函數,這些函數又做些什么呢?是這樣的,缺省構造函數和析構函數實際上什么也不做,它們只是讓你能夠創建和銷毀類的對象(對編譯器來說,將一些   "幕后"   行為的代碼放在此處也很方便   ----   參見條款33M24。)。注意,生成的析構函數一般是非虛擬的(參見條款14),除非它所在的類是從一個聲明了虛析構函數的基類繼承而來。缺省取址運算符只是返回對象的地址。這些函數實際上就如同下面所定義的那樣:  
  inline   Empty::Empty()   {}  
  inline   Empty::~Empty()   {}      
  inline   Empty   *   Empty::operator&()   {   return   this;   }      
  inline   const   Empty   *   Empty::operator&()   const   {   return   this;   }  
   
 
至于拷貝構造函數和賦值運算符,官方的規則是:缺省拷貝構造函數(賦值運算符)對類的非靜態數據成員進行   "以成員為單位的"   逐一拷貝構造(賦值)。即,如果m是類C中類型為T的非靜態數據成員,并且C沒有聲明拷貝構造函數(賦值運算符),m將會通過類型T的拷貝構造函數(賦值運算符)被拷貝構造(賦值)----   如果T有拷貝構造函數(賦值運算符)的話。如果沒有,規則遞歸應用到m的數據成員,直至找到一個拷貝構造函數(賦值運算符)或固定類型(例如,intdouble,指針,等)為止。默認情況下,固定類型的對象拷貝構造(賦值)時是從源對象到目標對象的   "逐位(每一個bit"   拷貝。對于從別的類繼承而來的類來說,這條規則適用于繼承層次結構中的每一層,所以,用戶自定義的構造函數和賦值運算符無論在哪一層被聲明,都會被調用。  
   
 
我希望這已經說得很清楚了。  
   
 
但怕萬一沒說清楚,還是給個例子。看這樣一個NamedObject模板的定義,它的實例是可以將名字和對象聯系起來的類:  
   
  template<class   T>  
  class   NamedObject   {  
  public:  
      NamedObject(const   char   *name,   const   T&   value);  
      NamedObject(const   string&   name,   const   T&   value);  
   
      ...  
   
  private:  
      string   nameValue;  
      T   objectValue;  
  };  
   
 
因為NamedObject類聲明了至少一個構造函數,編譯器將不會生成缺省構造函數;但因為沒有聲明拷貝構造函數和賦值運算符,編譯器將生成這些函數(如果需要的話)。  
   
 
看下面對拷貝構造函數的調用: 

  NamedObject<int>   no1("Smallest   Prime   Number",   2);  

  NamedObject<int>   no2(no1);      //   調用拷貝構造函數  
   
 
編譯器生成的拷貝構造函數必須分別用no1.nameValueno1.objectValue來初始化no2.nameValueno2.objectValuenameValue的類型是stringstring有一個拷貝構造函數(你可以在標準庫中查看string來證實   ----   參見條款49),所以no2.nameValue初始化時將調用string的拷貝構造函數,參數為no1.nameValue。另一方面,NamedObject<int>::objectValue的類型是int(因為這個模板實例中,Tint),int沒有定義拷貝構造函數,所以no2.objectValue是通過從no1.objectValue拷貝每一個比特(bit)而被初始化的。  
   
 
編譯器為NamedObject<int>生成的賦值運算符也以同樣的方式工作,但通常,編譯器生成的賦值運算符要想如上面所描述的那樣工作,與此相關的所有代碼必須合法且行為上要合理。如果這兩個條件中有一個不成立,編譯器將拒絕為你的類生成operator=,你就會在編譯時收到一些診斷信息。  
   
 
例如,假設NamedObject象這樣定義,nameValue是一個string的引用,objectValue是一個const   T  
   
  template<class   T>  
  class   NamedObject   {  
  public:  
      //  
這個構造函數不再有一個const名字參數,因為nameValue  
      //  
現在是一個非const   string的引用。char*構造函數  
      //  
也不見了,因為引用要指向的是string  
      NamedObject(string&   name,   const   T&   value);  
   
      ...                                                     //  
同上,假設沒有  
                                                                //  
聲明operator=  
  private:  
      string&   nameValue;                       //  
現在是一個引用  
      const   T   objectValue;                   //  
現在為const  
  };  
   
 
現在看看下面將會發生什么:  
   
  string   newDog("Persephone");  
  string   oldDog("Satch");  
   
  NamedObject<int>   p(newDog,   2);    //
正在我寫本書時,我們的愛犬Persephone即將過她的第二個生日 

  NamedObject<int>   s(oldDog,   29);    //   家犬Satch如果還活著,會有29歲了(從我童年時算起) 

  p   =   s;                       //   p中的數據成員將會發生些什么呢?  
   
 
賦值之前,p.nameValue指向某個string對象,s.nameValue也指向一個string,但并非同一個。賦值會給p.nameValue帶來怎樣的影響呢?賦值之后,p.nameValue應該指向   "s.nameValue所指向的string"   嗎,即,引用本身應該被修改嗎?如果是這樣,那太陽從西邊出來了,因為C++沒有辦法讓一個引用指向另一個不同的對象(參見條款M1)。或者,p.nameValue所指的string對象應該被修改嗎? 
   
 
面對這樣的難題C++拒絕編譯這段代碼。如果想讓一個包含引用成員的類支持賦值,你就得自己定義賦值運算符。對于包含const成員的類(例如上面被修改的類中的objectValue)來說,編譯器的處理也相似;因為修改const成員是不合法的,所以編譯器在隱式生成賦值函數時也會不知道怎么辦。還有,如果派生類的基類將標準賦值運算符聲明為private,編譯器也將拒絕為這個派生類生成賦值運算符。因為,編譯器為派生類生成的賦值運算符也應該處理基類部分(見條款16M33),但這樣做的話,就得調用對派生類來說無權訪問的基類成員函數,這當然是不可能的。   (所以類中含有引用類型、 const類型成員 最好重寫賦值運算符)

 

posted on 2010-09-04 19:29 肥仔 閱讀(938) 評論(0)  編輯 收藏 引用 所屬分類: C++ 基礎

青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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>
            亚洲免费人成在线视频观看| 国产精品分类| 亚洲日本免费| 久久亚洲国产精品一区二区| 国内成人精品视频| 欧美日韩成人在线观看| 欧美中在线观看| 日韩亚洲视频| 欧美国产欧美亚洲国产日韩mv天天看完整 | 中文日韩在线视频| 亚洲一卡二卡三卡四卡五卡| 亚洲激情视频在线播放| 亚洲三级性片| 一区在线免费| 欧美午夜精品久久久久免费视 | 99国产精品久久久久久久成人热| 久久久久久久久久看片| 亚洲欧美日韩久久精品 | 欧美 日韩 国产一区二区在线视频| 免费一级欧美片在线播放| 欧美大香线蕉线伊人久久国产精品| 欧美性色视频在线| 国产精品夜夜夜一区二区三区尤| 国产精品五月天| 亚洲成人原创| 午夜欧美不卡精品aaaaa| 免费看成人av| 亚洲专区欧美专区| 欧美国产一区二区三区激情无套| 国产精品久久久久久久久| 亚洲国产国产亚洲一二三| 亚洲一区精品电影| 亚洲国产va精品久久久不卡综合| 一区二区三区 在线观看视| 久久久久久久综合色一本| 国产精品久久久久久久久免费樱桃 | 亚洲国产第一| 久久综合伊人77777麻豆| 亚洲在线观看免费| 欧美大色视频| 日韩视频中文字幕| 亚洲精品久久| 亚洲国产欧美不卡在线观看| 国产日韩精品一区观看| 欧美日韩精品欧美日韩精品| 国产精品高清在线| 狠狠色丁香婷婷综合久久片| 中文欧美日韩| 亚洲韩国日本中文字幕| 久久久久欧美| 国产综合色在线| 性欧美超级视频| 99re视频这里只有精品| 欧美黄色aaaa| 亚洲激情另类| 欧美成人精品一区二区| 亚洲欧美日韩精品久久久| 欧美日本不卡高清| 亚洲激情视频| 亚洲激情综合| 欧美精品videossex性护士| 国产综合av| 久久久女女女女999久久| 欧美一二三区在线观看| 国产三级欧美三级| 久久精品国产第一区二区三区| 夜夜嗨av一区二区三区网页 | 亚洲人成精品久久久久| 看欧美日韩国产| 久久久久久有精品国产| 在线精品一区| 欧美激情久久久久久| 欧美成人日本| 99这里只有精品| 日韩天天综合| 国产色产综合产在线视频| 久久久久网址| 毛片基地黄久久久久久天堂 | 久久国产精品久久w女人spa| 亚洲欧美日韩电影| 国产主播一区二区| 亚洲第一在线综合网站| 欧美第一黄网免费网站| 亚洲深夜影院| 亚洲中无吗在线| 亚洲二区免费| 最近中文字幕mv在线一区二区三区四区 | 国产亚洲va综合人人澡精品| 久久免费视频这里只有精品| 免费高清在线一区| 亚洲一区二区三区激情| 欧美一区国产二区| 亚洲日本欧美在线| 久久男人av资源网站| 日韩天天综合| 国产免费观看久久| 欧美福利影院| 国产精品日韩电影| 欧美国产综合| 国产九九精品视频| 欧美激情亚洲| 国产日韩欧美中文| 亚洲七七久久综合桃花剧情介绍| 欧美日韩亚洲一区二区三区在线观看 | 免费短视频成人日韩| 欧美激情综合网| 久久精品99国产精品日本| 蜜桃久久精品一区二区| 午夜精品理论片| 欧美高清视频一区二区| 久久久久久久久久久久久久一区| 欧美日本不卡高清| 欧美成人免费一级人片100| 国产精品美女| 亚洲人成高清| 亚洲国产精品小视频| 香蕉免费一区二区三区在线观看| 一本色道久久综合狠狠躁篇怎么玩 | 久久久久看片| 欧美一区亚洲一区| 欧美日韩性生活视频| 欧美激情亚洲国产| 在线欧美小视频| 久久成人18免费观看| 欧美一级电影久久| 国产精品久久久久999| 99re亚洲国产精品| 一本色道久久综合狠狠躁篇的优点 | 欧美精品亚洲一区二区在线播放| 乱人伦精品视频在线观看| 国产视频久久久久| 亚洲欧美日韩国产另类专区| 亚洲一区二区视频在线| 欧美激情中文字幕在线| 亚洲国产成人精品久久| 欧美一区免费| 久久精品一区二区三区四区| 国产精品视频1区| 欧美一区观看| 国产嫩草一区二区三区在线观看 | 国产一区二区精品久久| 亚洲国产视频一区| 亚洲日韩视频| 欧美精品一区二区久久婷婷| 亚洲国产合集| 久久久久久91香蕉国产| 亚洲国产欧美一区二区三区同亚洲| 欧美成人在线免费观看| 亚洲五月六月| 中文久久乱码一区二区| 亚洲一区3d动漫同人无遮挡| 亚洲黑丝在线| 亚洲香蕉成视频在线观看| 亚洲免费中文| 亚洲成色777777女色窝| 一本色道久久综合亚洲精品不卡| 欧美一区二区三区电影在线观看| 欧美激情国产精品| 亚洲日本成人在线观看| 亚洲一区美女视频在线观看免费| 国产精品hd| 久久av一区二区三区| 女仆av观看一区| av成人天堂| 国产日韩欧美精品综合| 久久亚洲国产精品一区二区| 亚洲激情在线播放| 亚洲欧美在线x视频| 激情综合电影网| 欧美久久影院| 欧美亚洲视频| 亚洲精品之草原avav久久| 欧美一区二区三区电影在线观看| 影音先锋久久资源网| 欧美日韩亚洲免费| 久久精品99国产精品酒店日本| 亚洲国产色一区| 欧美一区二区三区四区在线观看| 亚洲国产精品久久| 国产精品一区毛片| 欧美国产综合视频| 欧美一区二区三区视频免费播放| 亚洲国产成人精品久久久国产成人一区 | 亚洲色图在线视频| 久久综合九色综合网站| 亚洲午夜极品| 亚洲国产精品高清久久久| 国产欧美韩日| 欧美午夜在线观看| 久久一二三四| 欧美亚洲系列| 在线一区观看| 亚洲精品一区在线观看香蕉| 久久这里有精品视频| 午夜在线精品偷拍| 在线亚洲免费| 一本色道久久综合狠狠躁的推荐| 在线看日韩欧美| 狠色狠色综合久久| 国产精品夜夜夜|