<2024年11月>
272829303112
3456789
10111213141516
17181920212223
24252627282930
1234567

统计

  • 随笔 - 13
  • 文章 - 0
  • 评论 - 2
  • 引用 - 0

常用链接

留言簿

随笔分类

随笔档案

搜索

  •  

最新评论

阅读排行榜

评论排行榜

成员函数作为线程函数

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

posted on 2010-11-05 20:05 @Koven.Z 阅读(2056) 评论(0)  编辑 收藏 引用 所属分类: C++


只有注册用户登录后才能发表评论。
网站导航: 博客园   IT新闻   BlogJava   知识库   博问   管理