关于C ++中函数指针的类函数和全局函数有什么区别?我问,因为如果函数是类成员,Windows CreateThread方法似乎不接受线程代码进入的函数。
当它是一个全局方法时,我可以将函数(线程代码进入)传递给CreateThread消息,但是一旦我使它成为类的成员,我得到错误“类型[方法布局]的参数是与LPTHREAD_START_ROUTINE类型的参数不兼容“。 ClassName :: *现在位于中间;这会影响吗?
解决这个问题的方法是什么?
答案 0 :(得分:5)
成员函数指针(DWORD(WINAPI Foo::*)(LPVOID)
)与函数指针(DWORD(WINAPI *)(LPVOID)
)的类型不同。成员函数具有隐藏的this
参数,导致签名不匹配。
最简单的方法是使用C ++ 11的<thread>
标题:
struct Foo {
void threadProc() {}
};
int main() {
Foo foo;
std::thread t{&Foo::threadProc, foo, /*other arguments to threadProc*/};
t.join();
}
如果您必须诉诸CreateThread
,请使用void *
参数传递实例:
struct Foo {
DWORD threadProc() {...}
};
extern "C" DWORD WINAPI proxyThreadProc(LPVOID userData) {
auto foo = static_cast<Foo *>(userData);
if (foo) {foo->threadProc();}
}
int main() {
Foo foo;
CreateThread(..., proxyThreadProc, &foo, ...);
}
你班上的那个人现在几乎可以随心所欲(如std::function
)并且仍在工作,只要在代理程序中使用正确的参数进行调用。
答案 1 :(得分:0)