如果試圖直接使用C++的成員函數作為回調函數將發生錯誤,甚至編譯就不能通過。其錯誤是普通的C++成員函數都隱含了一個傳遞函數作為參數,亦即“this”指針,C++通過傳遞this指針給其成員函數從而實現程序函數可以訪問C++的數據成員。這也可以理解為什么C++類的多個實例可以共享成員函數卻-有不同的數據成員。由于this指針的作用,使得將一個CALL-BACK型的成員函數作為回調函數安裝時就會因為隱含的this指針使得函數參數個數不匹配,從而導致回調函數安裝失敗。要解決這一問題的關鍵就是不讓this指針起作用,通過采用以下兩種典型技術可以解決在C++中使用回調函數所遇到的問題。這種方法具有通用性,適合于任何C++。
1). 不使用成員函數,為了訪問類的成員變量,可以使用友元操作符(friend),在C++中將該函數說明為類的友元即可。
2). 使用靜態成員函數,靜態成員函數不使用this指針作為隱含參數,這樣就可以作為回調函數了。靜態成員函數具有兩大特點:其一,可以在沒有類實例的情況下使用;其二,只能訪問靜態成員變量和靜態成員函數,不能訪問非靜態成員變量和非靜態成員函數。由于在C++中使用類成員函數作為回調函數的目的就是為了訪問所有的成員變量和成員函數,如果做不到這一點將不具有實際意義。解決的辦法也很簡單,就是使用一個靜態類指針作為類成員,通過在類創建時初始化該靜態指針,如pThis=this,然后在回調函數中通過該靜態指針就可以訪問所有成員變量和成員函數了。 這種處理辦法適用于只有一個類實例的情況,因為多個類實例將共享靜態類成員和靜態成員函數,這就導致靜態指針指向最后創建的類實例。為了避免這種情況,可以使用回調函數的一個參數來傳遞this指針,從而實現數據成員共享。這種方法稍稍麻煩,這里就不再贅述。
首先明白什么是回調函數:比如說被調函數void callbackf(int n){}要想作為回調函數的話,callbackf必須作為主調函數的形參出現,如void f(void (*p(int)),int n)形式才行!
例子:
例1:
}
int main()
{
void (*p)();
p=callback;
f(p);
return 0;
}
}
int main()
{
void (*p)();
p=A::callback;
f(p);
return 0;
}
}
};
int main()
{
A a;
void (*p)();
p=A::callback;
a.f(p);
return 0;
}
新聞熱點
疑難解答
圖片精選