在一个类中声明一个函数指针,在另一个类中声明一个函数,将该函数地址赋给该指针时出现:“error C3867: “XXX”: 函数调用缺少参数列表;请使用“&XXX”创建指向成员的指针”的错误:
/*CSeries.h*/
typedef void (CALLBACK* ONSERIESREAD)(void * pOwner, BYTE* buf, DWORD dwBufLen );
class CSeries
{
public:
CSeries(void);
~CSeries(void);
public:
ONSERIESREAD m_OnSeriesRead;
};
另一个类中:
/*CSerAssistantDlg.h*/
class CSerAssistantDlg : public CDialog
{
private:
void CALLBACK OnRecData(void * pOwner, BYTE* buf, DWORD dwBufLen);
};
//---------------------------使用时如下-------------------------
CSeries *mySer = new CSeries;
mySer->m_OnSeriesRead = OnRecData;
出现如下错误:
error C3867: “CSerAssistantDlg::OnRecData”: 函数调用缺少参数列表;请使用“&CSerAssistantDlg::OnRecData”创建指向成员的指针
错误原因是:静态成员函数的地址可用普通函数指针储存,而普通成员函数地址需要用类成员函数指针来储存,因为普通成员函数要执行时我们必须要确定他是属于哪个类对象才能执行,而类的static函数是不属于这个类的,他是在编译器编译时期就已经确定的,普通成员函数是在有了类对象之后才能执行。而OnRecData是普通成员函数地址
例如:声明一个类:class A{
public:
static void func1();
void func2();};
则会出现如下: typedef void (*b)();
b myfunc1 = func1; //valid
b myfunc2 = func2; //error
修改如下即可:
static void CALLBACK OnRecData(void * pOwner, BYTE* buf, DWORD dwBufLen);