C++中回調(diào)函數(shù)(CallBack)的用法分析
本文實例分析了C++中回調(diào)函數(shù)(CallBack)的用法。分享給大家供大家參考。具體分析如下:
如果試圖直接使用C++的成員函數(shù)作為回調(diào)函數(shù)將發(fā)生錯誤,甚至編譯就不能通過。
其錯誤是普通的C++成員函數(shù)都隱含了一個傳遞函數(shù)作為參數(shù),亦即“this”指針,C++通過傳遞this指針給其成員函數(shù)從而實現(xiàn)程序函數(shù)可以訪問C++的數(shù)據(jù)成員。這也可以理解為什么C++類的多個實例可以共享成員函數(shù)卻-有不同的數(shù)據(jù)成員。由于this指針的作用,使得將一個CALL-BACK型的成員函數(shù)作為回調(diào)函數(shù)安裝時就會因為隱含的this指針使得函數(shù)參數(shù)個數(shù)不匹配,從而導致回調(diào)函數(shù)安裝失敗。要解決這一問題的關鍵就是不讓this指針起作用,通過采用以下兩種典型技術可以解決在C++中使用回調(diào)函數(shù)所遇到的問題。這種方法具有通用性,適合于任何C++。
1). 不使用成員函數(shù),為了訪問類的成員變量,可以使用友元操作符(friend),在C++中將該函數(shù)說明為類的友元即可。
2). 使用靜態(tài)成員函數(shù),靜態(tài)成員函數(shù)不使用this指針作為隱含參數(shù),這樣就可以作為回調(diào)函數(shù)了。靜態(tài)成員函數(shù)具有兩大特點:其一,可以在沒有類實例的情況下使用;其二,只能訪問靜態(tài)成員變量和靜態(tài)成員函數(shù),不能訪問非靜態(tài)成員變量和非靜態(tài)成員函數(shù)。由于在C++中使用類成員函數(shù)作為回調(diào)函數(shù)的目的就是為了訪問所有的成員變量和成員函數(shù),如果做不到這一點將不具有實際意義。解決的辦法也很簡單,就是使用一個靜態(tài)類指針作為類成員,通過在類創(chuàng)建時初始化該靜態(tài)指針,如pThis=this,然后在回調(diào)函數(shù)中通過該靜態(tài)指針就可以訪問所有成員變量和成員函數(shù)了。
這種處理辦法適用于只有一個類實例的情況,因為多個類實例將共享靜態(tài)類成員和靜態(tài)成員函數(shù),這就導致靜態(tài)指針指向最后創(chuàng)建的類實例。為了避免這種情況,可以使用回調(diào)函數(shù)的一個參數(shù)來傳遞this指針,從而實現(xiàn)數(shù)據(jù)成員共享。這種方法稍稍麻煩,這里就不再贅述。
例子:
#include <iostream>
#include <assert.h>
using namespace std;
class Test
{
public:
friend void callBackFun(void){ cout << "CallBack Function!";} //因為callBackFun默認有一個const Test* 的指針
};
typedef void (*FPtr)(void);
void Fun(FPtr ptr)
{
ptr();
}
int main(void)
{
Fun(callBackFun);
return 0;
}
希望本文所述對大家的C++程序設計有所幫助。
相關文章
C++ throw關鍵字實現(xiàn)拋出異常和異常規(guī)范
本文主要介紹了C++ throw關鍵字實現(xiàn),文中通過示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下2021-08-08
C語言實例真題講解數(shù)據(jù)結構中單向環(huán)形鏈表
鏈表可以說是一種最為基礎的數(shù)據(jù)結構了,而單向鏈表更是基礎中的基礎。鏈表是由一組元素以特定的順序組合或鏈接在一起的,不同元素之間在邏輯上相鄰,但是在物理上并不一定相鄰。在維護一組數(shù)據(jù)集合時,就可以使用鏈表,這一點和數(shù)組很相似2022-04-04

