您好,登錄后才能下訂單哦!
C++中基類數組無法使用多態的原因是什么,針對這個問題,這篇文章詳細介紹了相對應的分析和解答,希望可以幫助更多想解決這個問題的小伙伴找到更簡單易行的方法。
數組的分配是采用:首地址+偏移量的方式,而偏移量是固定大小的,例如:Node arry[10];
arry[i] 的地址:&arry[0]+i*sizeof(Node);
當Node是含有虛函數的基類的時候,arry[]中保存的都是基類Node的元素,因為數組的取值方式便是固定偏移量的,一旦數組中存儲的是繼承類的話,那么這個數組的取值方式,會導致出現不可見的錯誤。(備注:通常情況下會認為這個元素是基類)。
例子:
#include <iostream>
using namespace std;
class Base {
public:
virtual void f();
virtual void print();
};
void Base::f() {
cout<<"Base f() ."<<endl;
}
void Base::print() {
cout<< "Base print() ."<<endl;
}
class Derive :public Base{
public:
virtual void f();
};
void Derive::f() {
cout<<"Derive f() ."<<endl;
}
int main() {
Base a[5]; // 這里存儲的是基類的數組
Derive d;
a[1] = d; // a[1]賦值 給繼承類
for(int i = 0; i <5; i++){
a[i].f();//這里都會當走基類來處理
}
Base* b[2] = {NULL,NULL}; // 存儲的是基類指針,指針的大小是固定的
b[0] = new Base();
b[1] = new Derive();
for(int i = 0; i <2; i++){
if (b[i] != NULL) {
b[i]->f();// 這里會輸出 繼承類的內容
delete b[i];
}
}
return 0;
}
Output:
Base f() .
Base f() .// a[0].f()
Base f() .
Base f() .
Base f() .
Base f() . // b[0]->f()
Derive f() . // b[1]->f()
輸出結果分析:
1.通過上面的輸出,可以看出一旦數組是基類,就算數組中的元素賦值為繼承類,也是被當作基類來使用。
2.非要在數組中使用多態的話,可以采用指針的方式,指針的偏移量是固定的,可以使繼承類的多態得到實現。
關于C++中基類數組無法使用多態的原因是什么問題的解答就分享到這里了,希望以上內容可以對大家有一定的幫助,如果你還有很多疑惑沒有解開,可以關注億速云行業資訊頻道了解更多相關知識。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。