C++ 结构作为AfxBeginThread中的参数
我尝试将结构作为参数传递 全球结构:C++ 结构作为AfxBeginThread中的参数,c++,C++,我尝试将结构作为参数传递 全球结构: struct ThreadParams { HWND window; LIB::ServiceContainer* mrt; }; 在主线程中: ThreadParams threadparams; threadparams.window = (HWND) GetSafeHwnd(); threadparams.mrt = m_rt; CWinThread* pthread1; pthread1 = (CWinThread*) AfxBeg
struct ThreadParams
{
HWND window;
LIB::ServiceContainer* mrt;
};
在主线程中:
ThreadParams threadparams;
threadparams.window = (HWND) GetSafeHwnd();
threadparams.mrt = m_rt;
CWinThread* pthread1;
pthread1 = (CWinThread*) AfxBeginThread(Thread1,(LPVOID)&threadparams,THREAD_PRIORITY_NORMAL,0,0,0);
课外活动:
UINT Thread1(LPVOID lp)
{
ThreadParams* threadparams = (ThreadParams*) lp;
HWND hmainWindow = threadparams->window;
LIB::ServiceContainer* m_rt = threadparams->mrt;
}
虽然它编译得很好,但我在运行时遇到了一个错误(这是一个意外的错误),我想我把指针m_rt弄糟了。你看到任何明显的错误了吗 在大多数情况下,您无法安全地访问在不同线程中分配的局部变量。当Thread1启动时,结构可能已经超出了主线程的范围。您应该找到另一种方法,例如在主线程中使用
new
分配参数,并在Thread1中使用完参数后将其删除。在大多数情况下,您无法安全地访问在不同线程中分配的局部变量。当Thread1启动时,结构可能已经超出了主线程的范围。您应该找到另一种方法,例如在主线程中使用new
分配参数,并在Thread1中使用完后将其删除
ThreadParams threadparams;
注意,如果它是一个局部变量,并且声明它的函数在创建线程后返回,那么线程引用一个不再存在的对象,因为局部变量在函数返回时被销毁。如果是这种情况,则使用new
创建一个新实例,如下所示:
ThreadParams * pthreadparams = new ThreadParams();
并将其传递给线程,这样即使创建线程的函数返回,它也将存在。当然,当您处理完它后,您必须手动删除它
注意,如果它是一个局部变量,并且声明它的函数在创建线程后返回,那么线程引用一个不再存在的对象,因为局部变量在函数返回时被销毁。如果是这种情况,则使用new
创建一个新实例,如下所示:
ThreadParams * pthreadparams = new ThreadParams();
并将其传递给线程,这样即使创建线程的函数返回,它也将存在。当然,当您处理完它后,您必须手动删除它。您能显示更多的调用代码吗?如果
threadparams
在线程运行时被破坏,那么该线程有一个悬空指针。可以显示更多调用代码吗?如果threadparams
在线程运行时被破坏,则该线程有一个悬空指针。