非静态成员作为线程函数

关于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);

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值