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

通關旅

softgamer的痕跡
posts - 16, comments - 13, trackbacks - 0, articles - 0

C++體會 -- 多態性

Posted on 2008-07-16 21:15 softgamer 閱讀(431) 評論(0)  編輯 收藏 引用
     
   我不想在這里講整個關于C++中的多態性機制,因為我自己描述完后,90%會誤人子弟,其實那些資料你可以在
   網
上搜索到一大堆。 我只想著重講一下我對于多態性中的動態多態性的一些使用總結。

   先簡單的說說多態性:不是說千手觀音。

   所謂多態性,簡單地說就是一個名稱,但是具有多種語義。多態性的發明有什么意義呢?考慮一下,現在你想      玩球。但是有很多種
   球,什么足球,網球,籃球,具體有多少種球類,請你登錄奧運網站查閱。程序必須去根   據不
同的球的類別給
   你選擇。于是你用 switch
   來根據   不同的情況來選擇不同的球。但是這樣做已經過時了,意   識到沒
有,它一點擴展性都沒有,一但需要   加入新的球的類別,你就
   不得不去修   改代碼----而不是擴展代碼。
   采用多態
性就不同了,利用多態性,你可以把一大堆的case語句替換為一個Ball函數。這就是它的神奇功能。

   多態性分為靜態多態性和動態多態性。
   函數重載可以實現靜態多態性,而要實現動態多態性就可以用----虛函數(virtual function),這也牽扯到繼
   承。

   1.如果以一個基礎類別的指針指向一個衍生類別的物件,那么經由此指針,你就只能呼叫基礎類別(而不是衍
        生類別)所定義的函數。

   2.如果你以一個衍生類別的指針,指向一個基礎類別的物件,你必須先做明顯的轉型動作(explicit cast), 
          這種作法很危險,不符合真實生活經驗,在程序設計上也會帶給程序員困惑。
 
   3.如果基礎類別和衍生類別都定義了相同名稱的成員函數,那么透過物件指針呼叫成員函數時,到底呼叫哪一  
        個函數,必須視該指針的原始類型而定,而不是視指針之實際所指之物件的類型而定。
         
   摘自《深入淺出MFC》

   好了,這些死板的遣詞造句就到這里了,下面著重看一下虛函數在多態性中的是怎么表現的。

   以下繼承論述的都是public繼承。

          #include <iostream>

          using namespace std;

          class CBallBase

          {

                public:

                void Ball()

                {

                   cout << "CBallBase::Ball was selected" << endl;

                }

 

            };

           class CBallDerive:public CBallBase

           {

                public:

                void Ball()

                {

                   cout << "CBallDerive::Ball was selected"<< endl;

                }

                void Ball2()
  
                {

                   cout << "CBallDerive::Ball2 was selected" << endl;

                }

            };

 

            int main()

            {

                CBallDerive  bd;

                CBall  b;

                CBall   *p=&bd;

                p->Ball();     //result:CBall::Ball was  selected if no virtual function affix

                //p->Ball2();  // error C2039: 'Ball2' : is not a member of 'CBall'

                //CBallDerive  *p2=&b;         // error C2440: 'initializing' :.....不能自動轉換

                CBallDerive*p2=(CBallDerive*)&b;

                p2->Ball();         //result:CBallDerive ::Ball was selected

                p2->Ball2();        //correct

                b=bd;           //correct 足球是球

                //b.Ball2();    //error C2039: 'Ball2' : is not a member of 'CBallBase'

                //bd=b;         //error   球不是足球

                return 0;

           }

           以上代碼執行結果:
 
           CBall::Ball  was selected

           CBallDerive::Ball was selected

           CBallDerive::Ball2 was selected

    代碼基本上反映了上面三點,那么為什么基類指針能夠名正言順地指向其派生類對象呢(甚至可以把一個
    派生類對象賦值給一個基類對象)?原因:派生類以public繼承基類時,由于包含了基類所有的元素(private
    除外),所有的派生類對象同時也是基類對象。另一方面,基類對象就不能賦值給派生類對象,但是如果是指    針的話,我們可以強制    轉換。那為什么說“不符合真實生活經驗,在程式設計上也會帶給程式員困惑。”呢?
    正如侯
先生論述的,物件導向觀念是描繪現實世界
    用的。水果類經過添加各種特征(屬性或方法)派生出蘋果類。我們
可以說蘋果是水果,但是卻不能說水果就
    是蘋果的。


    看這一句://b.Ball2();    //error C2039: Ball2' : is not a member of 'CBallBase'
 
    這里就涉及到切割(object slicing),

    看這段話你就會明白為什么它會出錯:“衍生物件通常都比基類物件大(記憶體空間),因為衍生物件不但繼承
    其基礎類別的成員,又有自己的成員。那么所謂的upcasting(向上強制轉型)將會造成物件的內容被切割(object
    slicing)。”

    在這里我要提取出第三點,先放在這里:如果基礎類別和衍生類別都定義了相同名稱之成員函數,那么透過物
    件
指標呼叫成員函數時,到底呼叫哪一個函數,必須視該指標的原始型別而定,而不是視指標之實際所指之物
    件的
型別而定。

    //////////////////////////////////////////////////////////////////////////////////////////////////////

    接下來讓我們看,當虛擬函數參合進來時,那些指針啊對象啊之類會出現什么情況。
    再在Cbase類的void Ball()前加上virtual, 然后結果就變成了

       CBall   *p=&bd;

       p->Ball();            //result:CBall::Ball was  selected if  without virtual function affix

       =====》

       CBallDerive::Ball  was called with virtual affix

       原來的結果是

       CBall::Ball  was selected  without virtual affix


       CBallDerive*p2=(CBallDerive*)&b;
 
       p2->Ball();         //result:CBallDerive ::Ball was selected

       =====》

       CBase::Ball was called  with virtual affix

       原來的結果是

       CBallDerive::Ball was selected without virtual affix


       p2->Ball2();              //correct

       =====》

       CBallDerive::Ball2 was called

       原來的結果是

       CBallDerive::Ball2 was selected

       當在基類中不使用virtual聲明會在其派生類中出現同名的Ball()函數時,如果基礎類別和衍生類別都定義了相同
       名稱Ball(),那么透過物件指針呼叫成員函數時,到底呼叫哪一個函數,必須視該指針的原始類
       型而定,這里的原始類型指的是CBallDerive*p2,而不是視指針之實際所指之物件(CBallDerive*)&b 的類型而定;

       當在基類中使用virtual聲明會在其派生類中出現同名的Ball()函數時,如果基礎類別和衍生類別都定義了相
       同名稱Ball()成員函數(且基類中的該函數被定義為virtual),那么透過物件指針呼叫成員函數時,到底呼
       叫哪一個函數,必須視該指針之實際所指之物件CBallDerive &bd的類型而定,而不是視指標的原始型CBall
  
     *p別而定!

 



只有注冊用戶登錄后才能發表評論。
網站導航: 博客園   IT新聞   BlogJava   博問   Chat2DB   管理


青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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>
            蜜桃av久久久亚洲精品| 免费成人av| 国产精品美女www爽爽爽| 一区二区三区精品在线| 日韩午夜在线| 国产精品视频免费在线观看| 亚洲综合精品一区二区| 亚洲视频图片小说| 国产专区综合网| 久久综合网hezyo| 蜜臀av国产精品久久久久| 亚洲精品在线观| 亚洲无毛电影| 国模精品一区二区三区色天香| 免费不卡在线视频| 欧美高清视频一区二区三区在线观看 | 欧美一级淫片播放口| 欧美一区二区三区免费看| 在线日本欧美| 99国产精品久久久久久久成人热| 国产精品美女久久久久aⅴ国产馆| 羞羞答答国产精品www一本 | 免费中文字幕日韩欧美| 欧美激情一区二区三区在线视频观看| 一本色道久久综合狠狠躁篇怎么玩 | 欧美一区二区三区日韩| 亚洲国产高清视频| 一本色道久久综合一区| 狠狠色狠色综合曰曰| 欧美激情无毛| 国产精品任我爽爆在线播放| 欧美成人激情在线| 国产精品国码视频| 欧美黄色一区| 国产欧美精品在线播放| 亚洲国产1区| 国产精品有限公司| 亚洲精品久久久久久下一站 | 国产精品久久久久久模特| 久久躁日日躁aaaaxxxx| 欧美日韩另类字幕中文| 久久亚洲影院| 国产精品自在线| 亚洲美女在线视频| 在线观看视频日韩| 午夜激情一区| 亚洲天堂视频在线观看| 久久综合亚州| 久久高清一区| 国产精品黄视频| 91久久黄色| 亚洲国产精品尤物yw在线观看| 亚洲综合欧美日韩| 一本一本久久a久久精品综合麻豆| 久久精品一区二区三区中文字幕| 亚洲影院在线| 欧美色大人视频| 亚洲黄色小视频| 亚洲国产精品激情在线观看| 久久国产一区| 久久综合给合久久狠狠色| 国产精品久久久久久户外露出| 亚洲国产精品激情在线观看| 影音先锋亚洲视频| 久久久久久久一区二区三区| 久久精品女人的天堂av| 国产精品蜜臀在线观看| 亚洲午夜一区二区三区| 亚洲女同在线| 国产精品视区| 亚洲欧美久久久| 久久av在线| 国内综合精品午夜久久资源| 欧美一区二区精品| 久色成人在线| 亚洲国产视频一区二区| 牛牛精品成人免费视频| 欧美激情影音先锋| 夜夜嗨av一区二区三区网页| 欧美特黄一级大片| 亚洲影院色无极综合| 欧美一区二区三区成人| 国产一区二区三区在线观看网站 | 欧美中文字幕在线播放| 欧美亚洲网站| 国产欧美亚洲日本| 久久九九热免费视频| 欧美激情精品久久久久久蜜臀| 91久久久久久久久| 欧美视频二区36p| 亚洲欧美日韩一区二区三区在线观看| 久久精品国产77777蜜臀 | 久久综合久久综合久久综合| 欧美激情一级片一区二区| 一区二区免费看| 国产欧美日韩视频在线观看| 久久久噜噜噜久久| 亚洲青涩在线| 久久激情综合网| 亚洲国产欧美在线| 国产精品乱人伦中文| 久久精品成人一区二区三区蜜臀| 欧美激情精品久久久久久黑人 | 国产日韩综合| 欧美大色视频| 亚洲免费在线精品一区| 免费高清在线视频一区·| 一本久道久久久| 国产一区二区三区在线观看视频 | 亚洲人成艺术| 国产资源精品在线观看| 欧美日韩国产不卡| 久久久精品一区| 亚洲小说欧美另类社区| 欧美丰满少妇xxxbbb| 欧美一区二区日韩一区二区| 亚洲理伦在线| 狠狠入ady亚洲精品| 欧美视频一区二区三区| 久久综合伊人77777蜜臀| 亚洲一区尤物| 日韩视频在线永久播放| 牛人盗摄一区二区三区视频| 午夜在线观看欧美| 99这里只有精品| 亚洲国产高潮在线观看| 国产一区导航| 国产精品美女一区二区在线观看| 欧美精品国产精品日韩精品| 久久九九免费| 欧美一区国产二区| 亚洲欧美综合另类中字| 亚洲视频播放| 日韩亚洲在线| 亚洲精品在线视频| 欧美激情一区二区三区成人| 噜噜噜噜噜久久久久久91| 欧美一区免费视频| 午夜国产不卡在线观看视频| 亚洲午夜视频在线| 亚洲午夜电影网| 一区二区三区色| 99国产精品| 99re热精品| 一区二区三区高清不卡| 一本色道久久加勒比精品| 亚洲美女啪啪| 日韩亚洲在线| 亚洲视频在线看| 亚洲字幕一区二区| 亚洲欧美日韩国产精品 | 亚洲国产精品一区二区www| 精品粉嫩aⅴ一区二区三区四区| 国产日本欧美一区二区三区在线| 国产精品亚洲视频| 国产日韩精品一区二区三区在线| 国产乱码精品一区二区三区av| 国产精品三区www17con| 国产欧美一区在线| 黄色一区二区三区| 亚洲国产成人porn| 亚洲精品欧美激情| 一区二区三区欧美| 欧美亚洲视频在线观看| 久久精品一区二区| 美国成人直播| 亚洲国产精品第一区二区三区| 亚洲精品免费电影| 一区二区不卡在线视频 午夜欧美不卡在 | 亚洲成人原创| 亚洲激情国产| 亚洲一区视频在线| 久久av一区二区三区| 猛干欧美女孩| 亚洲作爱视频| 久久久久久夜| 欧美少妇一区二区| 狠狠色丁香婷婷综合| 亚洲精品日韩精品| 午夜日韩电影| 欧美丰满高潮xxxx喷水动漫| 一区二区三区精密机械公司| 久久精品中文字幕一区二区三区| 欧美精品成人一区二区在线观看 | 欧美激情精品久久久久久变态| 欧美三级资源在线| 精品91视频| 亚洲少妇自拍| 免费精品视频| 亚洲免费视频在线观看| 欧美成人dvd在线视频| 国产精品制服诱惑| 日韩视频不卡中文| 久久一二三国产| 妖精成人www高清在线观看| 久久久噜噜噜久噜久久| 国产精品久久7| 亚洲精品一区在线观看| 久久久久久久久久码影片| 一区二区三欧美|