结构作为AfxBeginThread中的参数
Structure as parameter in AfxBeginThread
我尝试将结构作为参数传递。
全球结构:
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搞砸了。你看到明显的错误了吗?
ThreadParams threadparams;
请注意,如果它是一个局部变量,并且声明它的函数在创建线程后返回,那么线程引用的是一个不再存在的对象,因为当函数返回时,局部变量会被破坏。如果是这种情况,那么使用new
创建一个新实例,而不是:
ThreadParams * pthreadparams = new ThreadParams();
并将其传递给线程,这样即使创建线程的函数返回,它也会存在。当然,当你完成它时,你必须手动删除它。
在大多数情况下,您无法安全地访问在不同线程中分配的本地变量。当Thread1启动时,该结构可能已经超出了主线程的范围。您应该找到另一种方法,例如在主线程中使用new
分配参数,并在Thread1中完成这些参数后将其删除。
相关文章:
- 如何反转整数参数包
- 使用C++库在Android项目中修改gradle中的cmake参数,用于插入指令的测试
- 如何使用默认参数等选择模板专业化
- 模板参数替换失败,并且未完成隐式转换
- 具有默认模板参数的多态类的模板推导失败
- lambda参数转换为constexpr技巧,然后获取带链接的数组
- 将数组作为参数传递给函数安全吗?作为第三方职能部门,可以探索他们想要的之外的其他元素
- 函数调用中参数的顺序重要吗
- 部分定义/别名模板模板参数
- 模板-模板参数推导:三个不同的编译器三种不同的行为
- 使用不带参数的函数访问结构元素
- 基于另一个成员参数将函数调用从类传递给它的一个成员
- 如何在OMNET++中指定与命令行参数组合的输出文件名
- 如何使用Luacneneneba API正确读取字符串和表参数
- 在派生函数中指定void*参数
- 视图中的参数推导失败:take_while
- static_assert在宏中,但也可以扩展到可以用作函数参数的东西
- 使用指向成员的指针将成员函数作为参数传递
- 没有名称的C++模板参数
- 如何将enable-if与模板参数和参数包一起使用