1

我想在類中定義一個成員函數並使用它的指針。我知道我可以使用靜態成員函數,但問題在於我只能訪問該類的靜態成員。有沒有一種方法可以獲得函數指針,而不是靜態成員函數。一個類的非靜態成員函數的函數指針


更具體地說:有一個庫,我正在使用它獲取一個函數指針作爲其輸入。我想寫一個成員函數並將其函數指針分配給該外部庫。我應該創建一個類的對象還是使用這個指針來做到這一點?

+2

提示:你一定需要一個** **對象訪問非靜態成員。 –

+1

網上有很多教程:D [here](http://www.newty.de/fpt/fpt.html)和and [here](http://www.codeproject.com/Articles/7150/Member功能指針和最快可能)有一些例子。 –

+2

[是](http://www.parashift.com/c++-faq/pointers-to-members.html)。 –

回答

6

你可以得到該方法的指針,但它必須與對象

typedef void (T::*MethodPtr)(); 
MethodPtr method = &T::MethodA; 
T *obj = new T(); 
obj->*method(); 

如果你需要有非對象指針調用,你要使用的對象,那麼你必須存儲實例某個地方的對象,但是你只能使用一個對象(單例)。

class T { 
    static T *instance; 
public: 
    T::T() { 
    instance = this; 
    } 
    static void func() { 
    instance->doStuff(); 
    } 
    void doStuff() {} 
}; 

如果庫支持函數指針的用戶數據,那麼你可能有多個實例

class T { 
public: 
    static void func(void *instance) { 
    ((T*)instance)->doStuff(); 
    } 
    void doStuff() {} 
}; 
+0

其實我這樣做,但我有一個問題:http://stackoverflow.com/questions/14314507/issue-with-static-member-function-and-derived-class – Hesam

2
  • 如果:
  • 你想從內部獲得的非靜態成員的函數指針
  • 並在課堂上使用它:
  • 然後: 它可以工作,因爲當你得到成員函數地址時,有一個「this」指針。語法對我來說並不明顯,它可能看起來有點難看,但不會太糟糕。 對於真正的專家來說,這可能並不是新鮮事,但我很久以來一直希望在我的這些技巧中有這個。

下面是一個完整的示例程序:

#include <iostream> 
class CTestFncPtr 
{ 
public: 
    CTestFncPtr(int data) : mData(data) 
    { 
//  Switch = &CTestFncPtr::SwitchC; // Won't compile - wrong function prototype - this is type safe 
     if (data == 1) 
      Switch = &CTestFncPtr::SwitchA; 
     else 
      Switch = &CTestFncPtr::SwitchB; 
    } 
    void CallSwitch(char *charData) 
    { 
     (this->*Switch)(charData); 
    } 

private: 
    void SwitchA(char * charData) 
    { 
     std::cout << "Called Switch A " << "Class Data is " << mData<<" Parameter is " << charData<< "\n"; 
     Switch = &CTestFncPtr::SwitchB; 
    } 
    void SwitchB(char * charData) 
    { 
     std::cout << "Called Switch B " << "Class Data is " << mData<<" Parameter is " << charData<< "\n"; 
     Switch = &CTestFncPtr::SwitchA; 
    } 
    void SwitchC() 
    { 
    } 
    void(CTestFncPtr::*Switch)(char * charData); 
    int mData; 
}; 

int main(int argc, char * argv[]) 
{ 
    CTestFncPtr item1(1); 
    item1.CallSwitch("Item1"); 
    item1.CallSwitch("Switched call Item 1"); 
    CTestFncPtr item2(0); 
    item2.CallSwitch("Item2"); 
    item2.CallSwitch("Switched call Item 2"); 

    return 0; 
} 
相關問題