C++工作笔记-多继承下的一个大坑
生活随笔
收集整理的這篇文章主要介紹了
C++工作笔记-多继承下的一个大坑
小編覺得挺不錯的,現在分享給大家,幫大家做個參考.
當一個類多繼承了2個類,如類C,繼承了類A和B。創建了很多類C放到list<A*>這種容器中,一個list,保存的是類A的指針。
如果用類A直接轉成類B,這個類B是無法得到類C中繼承下來的類B的數據。
因為類A和類B沒有半毛錢關系。
具體例子如下:
代碼如下:
#include <iostream> #include <list> using namespace std;class MyBase{ public:int getMyValue(){ return m_myValue; }void setMyValue(int myValue){ m_myValue = myValue; }private:int m_myValue; };class MyItem{ public:void myPrint(){ cout << "MyItem Print Called" << endl; } };class MyClass :public MyBase,MyItem{ public:void printf(){ cout << "MyValue:" << MyBase::getMyValue() << endl; } };void main(){MyClass *myClass1 = new MyClass;MyClass *myClass2 = new MyClass;MyClass *myClass3 = new MyClass;myClass1->setMyValue(1);myClass2->setMyValue(2);myClass3->setMyValue(3);list<MyItem *> myList;myList.push_back((MyItem *)myClass1);myList.push_back((MyItem *)myClass2);myList.push_back((MyItem *)myClass3);list<MyItem *>::iterator iter;for (iter = myList.begin(); iter != myList.end(); iter++){cout << "把MyItem轉成MyBase:" <<((MyBase*)(*iter))->getMyValue() << endl;MyClass *my = ((MyClass*)(*iter));/*下斷點看看變量*/MyBase *a = ((MyBase*)(*iter));MyBase *b = ((MyBase*)my);/*下斷點看看變量*/cout << "把MyItem轉成MyClass:" <<my->getMyValue() << endl;cout << "把MyClass轉成MyBase:" <<((MyBase*)my)->getMyValue() << endl;}getchar(); }運行截圖如下:
下一個斷點,看看他們的地址,更加能得到結果:
總結
以上是生活随笔為你收集整理的C++工作笔记-多继承下的一个大坑的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: VS2012生成C的dll并调用以及Py
- 下一篇: C++|Qt之QTcpServer基本用