1). 不使用成員函數,直接使用普通C函數,爲了實現在C函數中可以訪問類的成員變量,可以使用友元操作符(friend),在C++中將該C函數說明爲類的友元即可。這種處理機制與普通的C編程中使用回調函數一樣。
2). 使用靜態成員函數,靜態成員函數不使用this指針作爲隱含參數,這樣就可以作爲回調函數了。靜態成員函數具有兩大特點:其一,可以在沒有類實例的情況下使用;其二,只能訪問靜態成員變量和靜態成員函數,不能訪問非靜態成員變量和非靜態成員函數。由於在C++中使用類成員函數作爲回調函數的目的就是爲了訪問所有的成員變量和成員函數,如果作不到這一點將不具有實際意義。解決的辦法也很簡單,就是使用一個靜態類指針作爲類成員,通過在類創建時初始化該靜態指針,如pThis=this,然後在回調函數中通過該靜態指針就可以訪問所有成員變量和成員函數了。這種處理辦法適用於只有一個類實例的情況,因爲多個類實例將共享靜態類成員和靜態成員函數,這就導致靜態指針指向最後創建的類實例。爲了避免這種情況,可以使用回調函數的一個參數來傳遞this指針,從而實現數據成員共享。這種方法見下面的例子:
class CTestClass
{
private:
typedef int (CTestClass::*FUNCPTR)(int, int);
int _A, _B;
int getPlusResult(int A, int B)
{
return A + B;
}
int getMultiplyResult(int A, int B)
{
return A * B;
}
protected:
int f(int a, int b, FUNCPTR ptr)
{
return (this->*ptr)(a, b);
}
public:
int GetAPlusB()
{
return f(_A, _B, getPlusResult);
}
int GetAMultiplyB()
{
return f(_A, _B, getMultiplyResult);
}
CTestClass(int A, int B): _B(B), _A(A) {};
~CTestClass(void);
};