Posted on 2007-03-13 11:36
kk 閱讀(891)
評論(2) 編輯 收藏 引用 所屬分類:
C++
上次寫了一下,結(jié)果漏洞百出,sigh。不過在高手的批評下,本人再多try了幾下,似乎又明白了不少,呵呵。如果有問題,請各位高手不吝賜教。謝謝哈!
下面演示了一下c++不支持雙分派。一共有四各類,A, AD, B, BE, 其中AD是A的子類,BE是B的子類。他們都有一個叫output的函數(shù)(函數(shù)名不一定要一樣的)。問題出現(xiàn)在哪里呢?問題出現(xiàn)在A或AD類中output函數(shù)里的b->output(a);這個語句。其中b是能夠動態(tài)track到他自己的類型的,但是a就不行了!因為它已經(jīng)被靜態(tài)綁定到A類型了,所以輸出結(jié)果是:
output信息:
///////////////////////////////
AD:BE
BE:A //如果正確的話,這里應(yīng)該輸出BE:AD
AD:B
B:A? //如果正確的話,這里應(yīng)該輸出B:AD
AD:BE
BE:A
A:B
B:A
///////////////////////////////
現(xiàn)在把接口改成AD*a, 顯示出錯信息:
error: invalid conversion from `A*' to `AD*'
///////////////////////////////
現(xiàn)在把b->output(a)改成b->output(this),輸出結(jié)果如下:
AD:BE
BE:AD
AD:B
B:AD
AD:BE
BE:A
A:B
B:A
///////////////////////////////
結(jié)果就正確了!因為this顯然已經(jīng)指向了正確的類型,而且也沒有經(jīng)過中間步驟地轉(zhuǎn)換,所以其信息還是能夠runtime找到的。
over。
不知上面的解釋是否正確,如果有問題,請各位高手賜教了。小弟先謝謝了。
代碼如下:
////////////////////////////////////
#include <iostream>
#include <list>
using namespace std;
class A;
class AD;
//B
class B
{
public:
?void virtual output(A * a){cout << "B:A" << endl;}
?void virtual output(AD * ad){cout << "B:AD" << endl;}
};
class BE : public B
{
public:
?void output(A * a){cout << "BE:A" << endl;}
?void output(AD * ad){cout << "BE:AD" << endl;}
};
//A
class A
{
public:
?void virtual output(B * b, A * a){cout << "A:B" << endl;b->output(a);}
?void virtual output(BE * b, A * a){cout << "A:BE" << endl;b->output(a);}
};
class AD : public A
{
public:
?void output(B * b, A * a){cout << "AD:B" << endl;b->output(a);}
?void output(BE * b, A * a){cout << "AD:BE" << endl;b->output(a);}
};
int main()
{
??? A * pAD = new AD;
??? pAD->output(new BE, pAD);
??? pAD->output(new B, pAD);
cout<<endl;
??? A * pA = new A;
??? pA->output(new BE, pA);
??? pA->output(new B, pA);
?
?return 0;
}
Feedback
# re: c++只支持單分派(single dispatch) 探討2 回復(fù) 更多評論
2007-03-13 13:28 by
class BE : public B
{
public:
void output(A * a){cout << "BE:A" << endl;}
void output(AD * ad){cout << "BE:AD" << endl;}
};
當(dāng)你呼叫b->output(a)時,由A的類型決定,而A的類型又由上一層virtual output(B * b, A * a)決定,所以他只能調(diào)用output(A * a)
但是用this后,這個傳遞進去就是類對像本身的類型,所以能得到你想要得到的結(jié)果.
兩個程序都沒有錯,錯在你對函數(shù)的重載理解上..
# re: c++只支持單分派(single dispatch) 探討2 回復(fù) 更多評論
2007-03-13 14:36 by
不是很明白你的意思哦。
我覺得問題出在了,output(A * a)的時候,它被靜態(tài)綁定到了A類型,而不是動態(tài)得runtime的得到它自己的類型哦。如果c++中能夠動態(tài)的決定參數(shù)的類型的話,那么它應(yīng)該調(diào)用的是output(AD * ad), 而不是output(A * a).