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

技術(shù)無極限

常用鏈接

統(tǒng)計

最新評論

多態(tài)~~我一直沒有形成理論化的知識

多態(tài)性,這個面向?qū)ο缶幊填I(lǐng)域的核心概念,本身的內(nèi)容博大精深,要以一文說清楚實在是不太可能。加之作者本人也還在不斷學(xué)習(xí)中,水平有限。因此本文只能描一下多態(tài)的輪廓,使讀者能夠了解個大概。如果有描的不準(zhǔn)的地方,歡迎指出,或與作者探討(作者Email:nicrosoft@sunistudio.com)  
           
          首先,什么是多態(tài)(Polymorphisn)?按字面的意思就是“多種形狀”。我手頭的書上沒有找到一個多態(tài)的理論性的概念的描述。暫且引用一下Charlie   Calverts的對多態(tài)的描述吧——多態(tài)性是允許你將父對象設(shè)置成為和一個或更多的他的子對象相等的技術(shù),賦值之后,父對象就可以根據(jù)當(dāng)前賦值給它的子對象的特性以不同的方式運(yùn)作(摘自“Delphi4   編程技術(shù)內(nèi)幕”)。簡單的說,就是一句話:允許將子類類型的指針賦值給父類類型的指針。多態(tài)性在Object   Pascal和C++中都是通過虛函數(shù)(Virtual   Function)實現(xiàn)的。  
           
          好,接著是“虛函數(shù)”(或者是“虛方法”)。虛函數(shù)就是允許被其子類重新定義的成員函數(shù)。而子類重新定義父類虛函數(shù)的做法,稱為“覆蓋”(override),或者稱為“重寫”。  
   
          這里有一個初學(xué)者經(jīng)常混淆的概念。覆蓋(override)和重載(overload)。上面說了,覆蓋是指子類重新定義父類的虛函數(shù)的做法。而重載,是指允許存在多個同名函數(shù),而這些函數(shù)的參數(shù)表不同(或許參數(shù)個數(shù)不同,或許參數(shù)類型不同,或許兩者都不同)。其實,重載的概念并不屬于“面向?qū)ο缶幊?#8221;,重載的實現(xiàn)是:編譯器根據(jù)函數(shù)不同的參數(shù)表,對同名函數(shù)的名稱做修飾,然后這些同名函數(shù)就成了不同的函數(shù)(至少對于編譯器來說是這樣的)。如,有兩個同名函數(shù):function   func(p:integer):integer;和function   func(p:string):integer;。那么編譯器做過修飾后的函數(shù)名稱可能是這樣的:int_func、str_func。對于這兩個函數(shù)的調(diào)用,在編譯器間就已經(jīng)確定了,是靜態(tài)的(記住:是靜態(tài))。也就是說,它們的地址在編譯期就綁定了(早綁定),因此,重載和多態(tài)無關(guān)!真正和多態(tài)相關(guān)的是“覆蓋”。當(dāng)子類重新定義了父類的虛函數(shù)后,父類指針根據(jù)賦給它的不同的子類指針,動態(tài)(記住:是動態(tài)!)的調(diào)用屬于子類的該函數(shù),這樣的函數(shù)調(diào)用在編譯期間是無法確定的(調(diào)用的子類的虛函數(shù)的地址無法給出)。因此,這樣的函數(shù)地址是在運(yùn)行期綁定的(晚邦定)。結(jié)論就是:重載只是一種語言特性,與多態(tài)無關(guān),與面向?qū)ο笠矡o關(guān)!  
           
          引用一句Bruce   Eckel的話:“不要犯傻,如果它不是晚邦定,它就不是多態(tài)。”  
           
          那么,多態(tài)的作用是什么呢?我們知道,封裝可以隱藏實現(xiàn)細(xì)節(jié),使得代碼模塊化;繼承可以擴(kuò)展已存在的代碼模塊(類);它們的目的都是為了——代碼重用。而多態(tài)則是為了實現(xiàn)另一個目的——接口重用!而且現(xiàn)實往往是,要有效重用代碼很難,而真正最具有價值的重用是接口重用,因為“接口是公司最有價值的資源。設(shè)計接口比用一堆類來實現(xiàn)這個接口更費(fèi)時間。而且接口需要耗費(fèi)更昂貴的人力的時間。”  
           
          其實,繼承的為重用代碼而存在的理由已經(jīng)越來越薄弱,因為“組合”可以很好的取代繼承的擴(kuò)展現(xiàn)有代碼的功能,而且“組合”的表現(xiàn)更好(至少可以防止“類爆炸”)。因此筆者個人認(rèn)為,繼承的存在很大程度上是作為“多態(tài)”的基礎(chǔ)而非擴(kuò)展現(xiàn)有代碼的方式了。  
           
          什么是接口重用?我們舉一個簡單的例子,假設(shè)我們有一個描述飛機(jī)的基類(Object   Pascal語言描述,下同):  
          type  
                  plane   =   class  
                  public  
                          procedure   fly();   virtual;   abstract;   //起飛純虛函數(shù)  
                          procedure   land();   virtual;   abstract;   //著陸純虛函數(shù)  
                          function   modal()   :   string;   virtual;   abstract;   //查尋型號純虛函數(shù)  
                  end;  
           
          然后,我們從plane派生出兩個子類,直升機(jī)(copter)和噴氣式飛機(jī)(jet):  
                  copter   =   class(plane)  
                  private  
                          fModal   :   String;  
                  public  
                          constructor   Create();  
                          destructor   Destroy();   override;  
                          procedure   fly();   override;  
                          procedure   land();   override;  
                          function   modal()   :   string;   override;  
                  end;  
           
                  jet   =   class(plane)  
                  private  
                          fModal   :   String;  
                  public  
                          constructor   Create();  
                          destructor   Destroy();   override;  
                          procedure   fly();   override;  
                          procedure   land();   override;  
                          function   modal()   :   string;   override;  
                  end;  
           
          現(xiàn)在,我們要完成一個飛機(jī)控制系統(tǒng),有一個全局的函數(shù)   plane_fly,它負(fù)責(zé)讓傳遞給它的飛機(jī)起飛,那么,只需要這樣:  
          procedure   plane_fly(const   pplane   :   plane);  
          begin  
                  pplane.fly();  
          end;  
          就可以讓所有傳給它的飛機(jī)(plane的子類對象)正常起飛!不管是直升機(jī)還是噴氣機(jī),甚至是現(xiàn)在還不存在的,以后會增加的飛碟。因為,每個子類都已經(jīng)定義了自己的起飛方式。  
           
          可以看到   plane_fly函數(shù)接受參數(shù)的是   plane類對象引用,而實際傳遞給它的都是   plane的子類對象,現(xiàn)在回想一下開頭所描述的“多態(tài)”:多態(tài)性是允許你將父對象設(shè)置成為和一個或更多的他的子對象相等的技術(shù),賦值之后,父對象就可以根據(jù)當(dāng)前賦值給它的子對象的特性以不同的方式運(yùn)作。  
           
          很顯然,parent   =   child;   就是多態(tài)的實質(zhì)!因為直升機(jī)“是一種”飛機(jī),噴氣機(jī)也“是一種”飛機(jī),因此,所有對飛機(jī)的操作,都可以對它們操作,此時,飛機(jī)類就作為一種接口。  
           
          多態(tài)的本質(zhì)就是將子類類型的指針賦值給父類類型的指針(在OP中是引用),只要這樣的賦值發(fā)生了,多態(tài)也就產(chǎn)生了,因為實行了“向上映射”。  
           
          應(yīng)用多態(tài)的例子非常普遍,在Delphi的VCL類庫中,最典型的就是:TObject類有一個虛擬的Destroy虛構(gòu)函數(shù)和一個非虛擬的Free函數(shù)。Free函數(shù)中是調(diào)用Destroy的。因此,當(dāng)我們對任何對象(都是TObject的子類對象)調(diào)用   .Free();之后,都會執(zhí)行   TObject.Free();,它會調(diào)用我們所使用的對象的析構(gòu)函數(shù)   Destroy();。這就保證了任何類型的對象都可以正確地被析構(gòu)。  
   
          多態(tài)性作為面向?qū)ο笞钪匾奶匦裕疚乃岵贿^是滄海一粟,還有很多內(nèi)容。如果可能,希望會有后文繼續(xù)探討多態(tài)

posted on 2010-01-19 09:39 勇敢空心人 閱讀(372) 評論(1)  編輯 收藏 引用 所屬分類: C/C++/算法

評論

# re: 多態(tài)~~我一直沒有形成理論化的知識 2010-01-31 22:10 不想成名

C++的重要特性:多態(tài),虛函數(shù),重載,模板  回復(fù)  更多評論   

青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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电影| 国产日韩在线一区| 国产日韩一区二区三区| 黑人一区二区三区四区五区| 韩日在线一区| 亚洲精品在线观看免费| 国产精品99久久久久久久久久久久| 亚洲一区在线免费观看| 欧美激情国产日韩精品一区18| 久久狠狠久久综合桃花| 久久九九热免费视频| 久久亚洲午夜电影| 久久免费黄色| 黄色成人在线| 欧美先锋影音| 国外成人在线视频网站| 亚洲国产欧洲综合997久久| 日韩一二在线观看| 久久精品国产免费观看| 欧美黄色精品| 一区二区三区www| 久久国产免费| 欧美吻胸吃奶大尺度电影| 国产视频综合在线| 亚洲毛片av| 久久久久久电影| 中文在线资源观看网站视频免费不卡| 久久久xxx| 国产精品专区第二| 亚洲精品一区二区三区婷婷月 | 奶水喷射视频一区| 正在播放亚洲| 欧美激情亚洲国产| 尤物精品国产第一福利三区| 亚洲综合色丁香婷婷六月图片| 欧美成人蜜桃| 欧美一区在线直播| 国产精品欧美在线| 中文日韩在线视频| 欧美高清hd18日本| 久久精品成人一区二区三区蜜臀| 欧美偷拍一区二区| 99精品福利视频| 毛片基地黄久久久久久天堂| 亚洲综合欧美日韩| 欧美视频国产精品| 一区二区三区国产精品| 欧美激情一区二区三区成人| 久久精品91久久久久久再现| 国产亚洲精品综合一区91| 亚洲一区二区在| 亚洲免费久久| 欧美日韩1区| 99精品国产在热久久下载| 亚洲国产精品123| 欧美在线国产| 国内一区二区三区| 久久先锋影音av| 久久av一区二区三区漫画| 国产欧美一区二区三区沐欲| 性伦欧美刺激片在线观看| 日韩天天综合| 欧美gay视频| 国产日韩亚洲欧美综合| 亚洲综合大片69999| 99精品国产99久久久久久福利| 欧美精品黄色| 亚洲视频在线一区| 亚洲视频你懂的| 国产欧美91| 久久久亚洲影院你懂的| 久久综合五月天婷婷伊人| 亚洲电影免费观看高清| 亚洲国产经典视频| 欧美视频中文字幕| 久久精品国语| 欧美大片免费久久精品三p| 宅男噜噜噜66一区二区| 亚洲欧美色一区| 狠狠爱www人成狠狠爱综合网| 久久夜色精品亚洲噜噜国产mv| 久久久久久综合| 亚洲精品系列| 亚洲欧美日韩一区二区| 亚洲黄色尤物视频| 亚洲一区二区在线播放| 精品51国产黑色丝袜高跟鞋| 91久久嫩草影院一区二区| 欧美日韩在线直播| 久久免费视频网站| 欧美啪啪一区| 久久久久久国产精品一区| 欧美77777| 久久精品99| 欧美精品一区二区三区一线天视频| 亚洲欧美中文字幕| 美女日韩在线中文字幕| 亚洲综合色噜噜狠狠| 久久国产主播精品| 亚洲女女女同性video| 久久久激情视频| 亚洲欧美中文另类| 欧美成人资源| 美女精品网站| 国产九九精品视频| 亚洲精品久久久久久久久久久久| 国产日韩亚洲| 亚洲午夜免费福利视频| 91久久嫩草影院一区二区| 亚洲欧美日韩在线不卡| 一区二区成人精品| 久久尤物电影视频在线观看| 亚洲自拍偷拍一区| 欧美激情导航| 嫩草影视亚洲| 国产亚洲欧洲| 亚洲欧美精品中文字幕在线| 日韩一区二区精品在线观看| 久久精品国产在热久久| 性久久久久久| 国产欧美日韩免费| 亚洲午夜激情网页| 亚洲一区二区视频在线| 欧美精品在线一区| 亚洲大胆女人| 亚洲国产专区校园欧美| 国产伦精品一区二区三区四区免费| 狠狠久久亚洲欧美| 99在线热播精品免费| 欧美电影免费观看高清| 欧美www视频在线观看| 亚洲天堂激情| 国产精品视频不卡| 在线国产精品一区| 亚洲欧美一区二区视频| 蜜臀va亚洲va欧美va天堂| 亚洲精选一区| 久久亚洲精品一区二区| 国产精品久久久久aaaa| 亚洲日本一区二区| 欧美在线观看一区| 日韩视频在线一区二区| 免费欧美视频| 亚洲动漫精品| 久久综合网色—综合色88| 欧美一二三视频| 国产精品裸体一区二区三区| 亚洲精品一区二区三区福利| 噜噜噜噜噜久久久久久91| 亚洲一区日韩| 国产精品欧美日韩| 亚洲欧美在线视频观看| 一区二区电影免费观看| 欧美三级第一页| 亚洲少妇中出一区| 亚洲图片欧洲图片av| 国产精品久久久久久久免费软件 | 欧美成人综合在线| 亚洲三级性片| av不卡在线看| 国产免费一区二区三区香蕉精| 性色av一区二区三区| 亚洲一区二区三区三| 亚洲第一网站| 欧美激情第4页| 午夜精品免费| 免费视频一区二区三区在线观看| 亚洲美女在线视频| 性久久久久久| 亚洲天堂网站在线观看视频| 在线综合欧美| 亚洲美女中出| 久久久久国产精品一区二区| 在线一区二区三区做爰视频网站| 亚洲欧美国产精品va在线观看| 亚洲二区在线视频| 欧美一区二区三区久久精品茉莉花| 亚洲成人在线免费| 欧美在线视频一区| 亚洲欧美日韩电影| 欧美色道久久88综合亚洲精品| 欧美1区3d| 亚洲二区在线| 久久只有精品| 亚洲福利在线视频| 亚洲第一在线| 久久免费视频这里只有精品| 久久久久久综合网天天| 国模私拍视频一区| 久久精品天堂| 久久久久久久波多野高潮日日| 国产精品女同互慰在线看| 一区二区高清视频在线观看| 亚洲视频一区二区免费在线观看| 欧美大片在线看| 一本色道久久88亚洲综合88| 亚洲一区美女视频在线观看免费| 国产精品二区在线|