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

5D空間

學(xué)習(xí)總結(jié)與經(jīng)驗(yàn)交流

   :: 首頁(yè) :: 新隨筆 :: 聯(lián)系 :: 聚合  :: 管理 ::
  在學(xué)習(xí)多重繼承、二義性、虛基類的時(shí)候遇到了一些困惑。經(jīng)過(guò)一定的學(xué)習(xí)摸索,雖然在底層機(jī)制上還不太清楚,但是在抽象層面上有了一定理解。
  書(shū)上只有一個(gè)虛基類的概念,即在繼承的時(shí)候加上關(guān)鍵字virtual。這里我們姑且把這種繼承方式叫做虛繼承。現(xiàn)在先來(lái)說(shuō)一下虛繼承和一般繼承的區(qū)別。
  要解釋這一系列問(wèn)題,我們首先要搞清楚這一系列概念意味著什么。多重繼承不用贅述。現(xiàn)在先就二義性和虛繼承談?wù)勎业目捶ā?br>
  在一般的繼承中(非虛繼承),每一個(gè)派生類都保存了一份完整的基類副本。考慮以下繼承:
class A
{
   
void print();
}
;

class B : public A
{
   
void print();
}
;

class C : public C
{
   
void print();
}
;

在這樣一系列繼承體系中,A包含一份print(),B包含了兩份,而C則包含了三分prin()。這里總共有6份獨(dú)立的print()函數(shù)。雖然在C中調(diào)用B::print()感覺(jué)和B中調(diào)用print()效果一樣,但他們確實(shí)是作為兩個(gè)副本存在。  而在虛繼承中,考慮如下繼承:
class A
{
   
void print();
}
;

class B : virtual public A
{
   
void print();
}
;

class C : virtual public C
{
   
void print();
}
;
B只含有一份print()副本,但是卻可以通過(guò)A::print()調(diào)用A的print()函數(shù)。同理,C也只包含了一份print()副本。這里總共只有3分print()副本。虛繼承中基類的數(shù)據(jù)并沒(méi)有變多一份給派生類,而只是使用權(quán)移交了,就好像A有一棟樓,虛繼承給B,名義上B也擁有了這棟樓,可以使用,但是并沒(méi)有真正為B另外建一棟一模一樣的樓。

  二義性:要解釋二義性,最好先定義一個(gè)概念:名字間隔。籠統(tǒng)地表達(dá),一個(gè)名字的間隔就是某個(gè)數(shù)據(jù)的名字從繼承層次中首次出現(xiàn)到達(dá)最后派生類時(shí)中間隔了多少相同的名字。間隔越少,這個(gè)名字的優(yōu)先級(jí)越高。當(dāng)然直接在最終類里面聲明的名字具有最高的優(yōu)先級(jí)。比如考慮一開(kāi)始的普通繼承:
class A
{
   
void print();
}
;

class B : public A
{
   
void print();
}
;

class C : public C
{
   
void print();
}
;

如果使用C的對(duì)象,那么A中的pirnt與C間隔最大,C中的print與C的間隔最短,所以如果直接調(diào)用C對(duì)象的print函數(shù),那么將調(diào)用C版本的print。如果C沒(méi)有定義一個(gè)print函數(shù),那么B中的print函數(shù)與C間隔最小,那么調(diào)用C對(duì)象的print函數(shù)時(shí),將調(diào)用B版本的print函數(shù)。
  有了這個(gè)概念,現(xiàn)在來(lái)解釋二義性:如果存在兩個(gè)及其以上的名字距離最終派生類的距離最短(長(zhǎng)度一樣),那么,根據(jù)剛才由名字間隔定義的優(yōu)先級(jí)別,在直接調(diào)用這個(gè)派生類對(duì)象的相應(yīng)數(shù)據(jù)時(shí),便不知道該調(diào)用哪個(gè)版本了(注意直接兩個(gè)字,因?yàn)榭梢酝ㄟ^(guò)二元::來(lái)分辨具體的版本以調(diào)用,所以即使名字存在二義性,如果未調(diào)用這些名字,編譯器可能不會(huì)報(bào)錯(cuò))。有兩種情況(到目前為止我看到的)可能導(dǎo)致二義性:1、在類中聲明了兩個(gè)名字一樣的成員:這是最糟糕的情況,因?yàn)槿绻@樣做了,沒(méi)有辦法彌補(bǔ),但這也是最好的情況,因?yàn)榫幾g器根本不會(huì)讓你這么做。2、多繼承的時(shí)候繼承了兩個(gè)間隔一樣的名字:通常難以對(duì)付的是這種情況。
  關(guān)于上述第二種情況(多繼承),這些具有二義性的名字可能1、來(lái)自兩個(gè)基類各自的聲明,2、也可能來(lái)自兩個(gè)基類繼承自更高層次的同一基類(菱形繼承),3、也可能其中一個(gè)名字來(lái)自基類聲明,另一個(gè)名字來(lái)自另一個(gè)基類對(duì)更高層次基類的繼承。無(wú)論如何,只要同時(shí)存在兩個(gè)及其以上具有如果存在兩個(gè)及其以上的名字距離最終派生類的距離最短(長(zhǎng)度一樣),那么就存在二義性。

1、來(lái)自兩個(gè)基類各自聲明
class B1
{
   
void print();
}
;

class B2 :
{
   
void print();
}
;

class C : public B1, public B2
{
}
;

2、菱形繼承
class A
{
   
void print();
}
;

class B1 : public A
{
}
;

class B2 : public A
{
}
;

class C : public B1, public B2
{
}
;

3、其中一個(gè)名字來(lái)自基類聲明,另一個(gè)名字來(lái)自另一個(gè)基類對(duì)更高層次基類的繼承
class A
{
   
void print();
}
;

class B1 : public A
{
}
;

class B2 :
{
   
void print();   
}
;

class C : public B1, public B2
{
}
;
(注意:雖然A版本的print是通過(guò)B1到達(dá)C的,但是A->B1->C的過(guò)程中,A版本的print與C之間并沒(méi)有間隔其他的print,這與B2版本的print一樣,所以他們具有相同的名字間隔,因此具有二義性)

  二義性的解決辦法:
  1、在最終派生類中定義一個(gè)相同名字的成員,這樣這個(gè)名字距離最終派生類最近,所以就會(huì)調(diào)用這個(gè)名字下的數(shù)據(jù)(通常教材里叫做這個(gè)名字把其他名字隱藏了)。這個(gè)名字(如果是函數(shù))你可以自己定義新的方法,也可以通過(guò)二元::調(diào)用你已知的存在二義性的名字中的某一個(gè)(注意:如果你選擇的調(diào)用版本不是該派生類的直接基類,那么該如何調(diào)用呢?比如A->B->C,那么從C的對(duì)象c調(diào)用A的print函數(shù),c.A::print()是否可行?我在vs2010上,雖然報(bào)錯(cuò)但是編譯通過(guò)且正常運(yùn)行。如果各位有任何見(jiàn)解或建議,希望不吝賜教。)
  2、使用虛繼承(針對(duì)菱形繼承等):回想一下虛繼承和普通繼承,通過(guò)虛繼承的方法可以消除重復(fù)副本帶來(lái)的二義性問(wèn)題。比如在某一繼承層次上,這個(gè)某兩個(gè)名字具有二義性,然而順著繼承層次向上分析,卻發(fā)現(xiàn)這兩個(gè)名字其實(shí)是同一個(gè)東西的兩個(gè)副本,這個(gè)時(shí)候如果使用虛繼承,那么就使得這兩個(gè)副本變?yōu)橐粋€(gè)副本(準(zhǔn)確地說(shuō),兩個(gè)副本都沒(méi)有了,因?yàn)橹淮嬖谒麄児不惖哪欠輸?shù)據(jù),虛基類得到的不過(guò)是使用權(quán))。

寫(xiě)在后面:
  注意虛函數(shù)和虛繼承的區(qū)別:虛函數(shù)并沒(méi)有減少任何數(shù)據(jù)的存在,僅僅相當(dāng)于在基類指針層面上建立了一種“調(diào)用最靠近對(duì)象類型的函數(shù)”的機(jī)制。然而虛繼承則是一種類的繼承方式,即,只創(chuàng)建派生類特有部分的數(shù)據(jù),繼承的數(shù)據(jù)按需從基類索取。所以雖然他們都是用virtual關(guān)鍵字,但似乎意思上聯(lián)系不大。
  另外,是用虛繼承能夠解決的問(wèn)題相當(dāng)有限。而且虛繼承面臨一個(gè)開(kāi)銷問(wèn)題,雖然從繼承層面上看,這是一個(gè)消除二義性的好方法,而且似乎對(duì)編程沒(méi)有什么副作用。這個(gè)道理與虛函數(shù)帶來(lái)的好處與開(kāi)銷權(quán)衡問(wèn)題差不多。一些書(shū)希望把這個(gè)問(wèn)題留個(gè)程序員自己權(quán)衡,一些書(shū)則建議一律使用虛函數(shù)。不過(guò)應(yīng)該指出,現(xiàn)在硬件設(shè)備能力的提升速度似乎在不斷削弱我們對(duì)開(kāi)銷問(wèn)題的顧忌(只要算法上不存在問(wèn)題),所以即使你不打算從現(xiàn)在開(kāi)始就全盤(pán)使用虛函數(shù)以及虛繼承(而且對(duì)于一般的小程序,即使不斷加上這些關(guān)鍵字也會(huì)使人厭煩吧,況且有些類似乎一輩子也不會(huì)成為基類呢?),但是請(qǐng)至少保持這樣一個(gè)念頭,多一種打算,多一條路嘛。
posted on 2011-04-04 17:24 今晚打老虎 閱讀(3475) 評(píng)論(2)  編輯 收藏 引用 所屬分類: 學(xué)習(xí)筆記

評(píng)論

# re: 多重繼承、二義性、虛基類(虛繼承)之我見(jiàn) 2012-05-29 18:18 自己繼承自己
孩子,代碼打錯(cuò)了。

class C : public C
自己繼承自己?  回復(fù)  更多評(píng)論
  

# re: 多重繼承、二義性、虛基類(虛繼承)之我見(jiàn) 2012-07-20 13:14 CL
可以啊,自慰.@自己繼承自己
  回復(fù)  更多評(píng)論
  

青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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>
            久久精品国产一区二区电影 | 一区二区国产日产| 亚洲高清免费在线| 久久亚洲免费| 99re66热这里只有精品4| 亚洲精品乱码久久久久久蜜桃91| 欧美精品v国产精品v日韩精品| 日韩亚洲精品电影| 亚洲网站在线| 国产一区二区视频在线观看 | 亚洲一区日本| 午夜精品成人在线视频| 极品裸体白嫩激情啪啪国产精品| 欧美亚洲综合在线| 国产三区精品| 欧美二区在线| 国产精品久久国产愉拍 | 9人人澡人人爽人人精品| 99riav久久精品riav| 国产亚洲欧美日韩在线一区| 亚洲丰满少妇videoshd| 欧美日韩在线影院| 久久久久国内| 欧美日韩一区高清| 久久乐国产精品| 欧美日韩国产综合视频在线观看中文 | 老司机久久99久久精品播放免费| 亚洲精品欧美| 欧美专区在线播放| 亚洲视频在线观看| 农村妇女精品| 久久久久久久久综合| 欧美日韩亚洲视频一区| 老司机67194精品线观看| 欧美日韩精品高清| 欧美大片91| 国语精品一区| 亚洲一区二区网站| 中文欧美在线视频| 欧美成人一区二区在线| 久久精品欧洲| 国产精品免费区二区三区观看| 欧美粗暴jizz性欧美20| 国产亚洲一区二区精品| 99精品免费网| 亚洲精选在线观看| 美女视频黄 久久| 老司机午夜精品视频在线观看| 国产精品久久久久高潮| 91久久极品少妇xxxxⅹ软件| 精品91久久久久| 欧美一区=区| 欧美中日韩免费视频| 国产精品国产三级国产aⅴ浪潮| 欧美国产亚洲精品久久久8v| 韩日成人在线| 久久国产色av| 久久精品国产91精品亚洲| 国产精品福利在线观看网址| 亚洲三级电影在线观看| 99精品国产热久久91蜜凸| 欧美aⅴ一区二区三区视频| 美女主播一区| 亚洲第一福利在线观看| 久久综合久久久| 欧美国产另类| 日韩视频一区二区| 欧美日韩精品二区第二页| 亚洲精品乱码久久久久久按摩观| 一区二区三区免费网站| 欧美日韩国产综合网| 亚洲精品一区二区三区四区高清| 日韩午夜中文字幕| 欧美性色综合| 亚洲欧美日韩一区在线| 久久久久国产精品人| 国产综合久久久久久| 1769国内精品视频在线播放| 性8sex亚洲区入口| 麻豆精品视频在线观看| 亚洲福利视频免费观看| 男人插女人欧美| 一区二区三区国产精品| 欧美一区午夜精品| 国内在线观看一区二区三区| 欧美成年人视频网站欧美| 夜色激情一区二区| 久久成人综合网| 亚洲福利电影| 国产精品久久二区| 久久久久久穴| 日韩一级黄色片| 久久久噜噜噜久久中文字幕色伊伊| 亚洲国产精品t66y| 国产精品乱子乱xxxx| 久久一区二区视频| 亚洲一二三区在线| 免费视频久久| 亚洲一区在线直播| 亚洲成色777777女色窝| 欧美日韩亚洲国产精品| 久久久91精品国产一区二区三区| 欧美激情一区二区久久久| 一区二区精品在线| 韩国三级在线一区| 国产精品久久久久毛片大屁完整版| 欧美中文字幕精品| 亚洲欧洲在线播放| 久久婷婷丁香| 午夜精品久久久久久久99热浪潮 | 欧美久久久久久蜜桃| 欧美一区二区三区另类 | 欧美大片国产精品| 欧美有码在线观看视频| 一区二区三区 在线观看视| 激情文学一区| 国产精品一区在线观看你懂的| 欧美不卡三区| 久久久www| 午夜精品亚洲| 亚洲直播在线一区| 日韩一级网站| 亚洲日本电影| 亚洲国产岛国毛片在线| 美女精品国产| 久久综合99re88久久爱| 午夜精品在线看| 亚洲午夜高清视频| 日韩亚洲视频在线| 亚洲日韩欧美一区二区在线| 国产真实久久| 国产麻豆综合| 国产欧美精品日韩区二区麻豆天美| 欧美日韩亚洲一区| 欧美日韩一区成人| 欧美三区不卡| 欧美午夜精品久久久久久久 | 国产美女精品免费电影| 国产精品久久国产愉拍| 欧美亚州在线观看| 欧美日韩在线综合| 国产精品videosex极品| 国产精品久久久对白| 欧美三区免费完整视频在线观看| 欧美母乳在线| 欧美性猛交xxxx免费看久久久| 欧美性大战久久久久久久| 国产精品乱码| 久久久久九九九| 久久久久久久999精品视频| 久久久久久久久一区二区| 久久久久久亚洲精品不卡4k岛国| 久久久国产精品一区二区中文 | 久久在线免费| 免费不卡在线观看| 亚洲高清在线观看| 日韩视频在线观看一区二区| 日韩视频在线你懂得| 一本久久知道综合久久| 亚洲欧美成人一区二区三区| 午夜在线a亚洲v天堂网2018| 久久激情综合网| 久久资源av| 欧美日韩视频在线一区二区| 国产精品视频导航| 国产视频在线观看一区二区三区| 精品69视频一区二区三区| 亚洲精品社区| 午夜在线精品偷拍| 久久久久久一区二区| 亚洲国产日韩在线| 亚洲影视九九影院在线观看| 久久久久国产精品一区| 欧美激情bt| 国产欧美精品一区| 亚洲欧洲精品一区二区精品久久久| 在线综合亚洲欧美在线视频| 久久成人人人人精品欧| 欧美福利电影在线观看| 亚洲视频在线观看网站| 美女视频黄免费的久久| 国产精品欧美一区喷水 | 国产精品对白刺激久久久| 激情伊人五月天久久综合| 一区二区福利| 久久综合五月| 亚洲一区二区三区四区中文| 免费日韩av电影| 国产美女搞久久| 亚洲午夜免费福利视频| 久久最新视频| 亚洲综合激情| 欧美日韩精选| 亚洲片国产一区一级在线观看| 午夜精品久久久久久99热| 亚洲国产专区校园欧美| 久久精品2019中文字幕| 国产精品成人aaaaa网站 | 国产精品午夜视频| 一本一本久久|