关于this指针的传递问题总结
1:__cdecl成员函数 通过ECX传递this指针
mov ecx, 对象的地址
call 成员函数
2:__stdcall成员函数 通过堆栈传递this指针
push 对象的地址
call 成员函数
用非静态成员作为线程函数
原理分析:
1.该线程的主函数为类的非静态成员函数,所以它认为他的调用者会为他传递一个this指针,通过堆栈传递.因为__stdcall的函数
2.而操作系统认为的线程主函数只有一个参数通过堆栈传递.
所以线程的this指针被&b覆盖了,刚好把非静态成员函数作为线程主函数
class CObject
{
public:
CObject(int a){ m_nData = a;};
DWORD WINAPI ThreadFuc()
{
printf("Thread Run\nThread Data:%d \n", m_nData);
return 0;
};
private:
int m_nData;
};
typedef DWORD ( CObject::*MyThread)(
LPVOID lpThreadParameter
);
int main(int argc, char** argv)
{
MyThread My = (MyThread)&CObject::ThreadFuc;
CObject b(10);
HANDLE hThread = ::CreateThread(NULL, NULL, *(LPTHREAD_START_ROUTINE*)&My, &b, NULL, NULL);
system("pause");
::CloseHandle(hThread);
return 0;
}
以上内容转自VCKBASE,经过测试,可以正常运行。
使用时注意一下几点:
1.如果使用AfxBeginThread,强制转换的类型应该是AFX_THREADPROC
以下是我使用时候的代码:
typedef UINT ( CDlgMutex_Test::*WOLF_HTREADPROC)(LPVOID);
WOLF_HTREADPROC myThread1 = (WOLF_HTREADPROC)&CDlgMutex_Test::Thread1;
WOLF_HTREADPROC myThread2 = (WOLF_HTREADPROC)&CDlgMutex_Test::Thread2;
AfxBeginThread(*(AFX_THREADPROC*)&myThread1,this);
AfxBeginThread(*(AFX_THREADPROC*)&myThread2,this);
本文来自CSDN博客,转载请标明出处:http://blog.csdn.net/haoxing168/archive/2009/08/16/4452360.aspx
附:其他一个.CPP
#include <windows.h>
#include <conio.h>
#include <stdio.h>
class t
{
public:
void Run();
t();
protected:
char c[256];
DWORD WINAPI ThreadFunc();
};
typedef DWORD (WINAPI t::* pThreadFunc)();
t::t()
{
strcpy(c, "Welcome to use thread proc");
}
DWORD WINAPI t::ThreadFunc()
{
MessageBox(NULL, c, "xixi", MB_OK);
return 0;
}
typedef DWORD (WINAPI * PTHREADFUNC)(LPVOID);
void t::Run()
{
pThreadFunc p = ThreadFunc;
DWORD dwAddress;
memcpy(&dwAddress,&p,sizeof(p));
PTHREADFUNC p1;
memcpy(&p1, &dwAddress, sizeof(p1));
DWORD dwTID;
HANDLE hf;
hf = CreateThread(NULL, 0, p1, this, 0, &dwTID);
if (hf){
CloseHandle(hf);
}
}
void main()
{
t t1;
t1.Run();
getch();
}