我們來談一下重載C++標準庫函數時候會發生什么樣的問題呢?接下來會通過重載MFC的MessageBox讓你知道不一樣的MFC。
一、messagebox的原始調用方法
我們隨便新建一個MFC的對話框工程,先給出兩種messagebox的調用方法,如下所示:
void CMy200Dlg::OnBnClickedButton1()
{
//1. 調用CMy200Dlg類基類CWnd的方法MessageBox
MessageBox(_T("CWnd's method!"),_T("123!"),0);
//2. 調用windows API的MessageBox function
::MessageBox(NULL,_T("API funtion!"),NULL,0);
}
二、CMy200Dlg類中對messagebox方法的重載
下面來改造MessageBox這個函數,第1種是在CMy200Dlg這個類中重載
//d:\My Documents\Visual Studio 2005\Projects\200\200\200Dlg.h
class CMy200Dlg : public CDialog
{
public:
int MessageBox();
};
//d:\My Documents\Visual Studio 2005\Projects\200\200\200Dlg.cpp
int CMy200Dlg::MessageBox()
{
int a=0,b=1;
return a+b;
}
void CMy200Dlg::OnBnClickedButton1()
{
//方法1. 調用CMy200Dlg類基類CWnd的方法MessageBox
CWnd::MessageBox(_T("CWnd's method!"),_T("123!"),0);
//方法2. 調用windows API的MessageBox function
::MessageBox(NULL,_T("API funtion!"),NULL,0);
//方法3. 調用重載的MessageBox()
MessageBox();
}
為什么1.中的MessageBox必須加上CWnd::限定符,因為在CMy200Dlg中重載了MessageBox后會對基類的函數進行覆蓋,這個是必須要引起注意的。
三、全局中對messagebox方法的重載
下面繼續來重載MessageBox這個函數,第2種是在全局中進行重載
int CMy200Dlg::MessageBox()
{
int a=0,b=1;
return a+b;
}
int MessageBox(int aa,int bb)
{
return aa*bb;
}
void CMy200Dlg::OnBnClickedButton1()
{
//1. 調用CMy200Dlg類基類CWnd的方法MessageBox
CWnd::MessageBox(_T("CWnd's method!"),_T("123!"),0);
//2. 調用windows API的MessageBox function
::MessageBox(NULL,_T("API funtion!"),NULL,0);
//3. 調用重載的MessageBox()
MessageBox();
//4. 調用重載的全局函數 MessageBox(int aa,int bb)
::MessageBox(20,14);
}
記住全局函數的調用加上::作用域符號就可以了。
四、結論:
一個知識點的靈活運用關鍵是勤動手,多調試,多去思考和總結。作為上一篇函數的重載就這樣講完了,但是子類對基類的覆蓋這個概念沒有展開來說,留給以后再去細說吧 www.yztrans.com