本篇內(nèi)容主要講解“C++如何通過指針或引用訪問多態(tài)對象”,感興趣的朋友不妨來看看。本文介紹的方法操作簡單快捷,實用性強。下面就讓小編來帶大家學習“C++如何通過指針或引用訪問多態(tài)對象”吧!
專注于為中小企業(yè)提供成都網(wǎng)站建設(shè)、成都網(wǎng)站制作服務,電腦端+手機端+微信端的三站合一,更高效的管理,為中小企業(yè)從化免費做網(wǎng)站提供優(yōu)質(zhì)的服務。我們立足成都,凝聚了一批互聯(lián)網(wǎng)行業(yè)人才,有力地推動了上千企業(yè)的穩(wěn)健成長,幫助中小企業(yè)通過網(wǎng)站建設(shè)實現(xiàn)規(guī)模擴充和轉(zhuǎn)變。
通過指針或引用訪問多態(tài)對象
If you have a class with a virtual function, you don't (in general) know which class provided the function to be used.
如果類有虛函數(shù),通常不會知道使用的函數(shù)具體是由那個(派生)類提供的。
struct B { int a; virtual int f(); virtual ~B() = default };
struct D : B { int b; int f() override; };
void use(B b)
{
D d;
B b2 = d; // slice
B b3 = b;
}
void use2()
{
D d;
use(d); // slice
}
Both ds are sliced.
兩個(函數(shù)中的)d都被切斷了(因為派生類對象向基類對象賦值,譯者注)
You can safely access a named polymorphic object in the scope of its definition, just don't slice it.
你可以在多態(tài)對象被定義的作用域中通過變量名安全地使用它,只要注意不被切斷就行。
void use3()
{
D d;
d.f(); // OK
}
A polymorphic class should suppress copying(多態(tài)類應該抑制復制)
Flag all slicing.(標記發(fā)生數(shù)據(jù)切斷的操作)
到此,相信大家對“C++如何通過指針或引用訪問多態(tài)對象”有了更深的了解,不妨來實際操作一番吧!這里是創(chuàng)新互聯(lián)網(wǎng)站,更多相關(guān)內(nèi)容可以進入相關(guān)頻道進行查詢,關(guān)注我們,繼續(xù)學習!