将shared_ptr或unique_ptr传递给_beginthreadex
Passing a shared_ptr or unique_ptr to _beginthreadex
我想知道这是否可能。创建一个TestClass类型的shared_ptr或unique_ptr。
然后调用_beginthreadex,并将类的静态方法作为要执行的函数传递给它,并将之前创建的shared_ptr或unique_ptr作为数据传递给它。像这样:
shared_ptr<TestClass> p = make_shared<TestClass>(count, "test");
HANDLE hth1 = (HANDLE)_beginthreadex(NULL, 0, p->ThreadStart,p, 0, NULL);
我通常在没有智能指针的情况下使用这种方法,我通常创建一个TestClass的普通指针,并将TestClass的静态方法和指针本身作为数据传递,然后在静态方法内部将其强制转换为(TestClass*)并运行该类的成员方法等,完成工作,当线程完成时,我删除指针。类似这样的东西:
TestClass * p = new TestClass(count, "test");
HANDLE hth1 = (HANDLE)_beginthreadex(NULL, 0, p->ThreadStart,p, 0, NULL);
我想要实现的是使智能指针在线程结束时自动删除对象,因为智能指针将超出范围。
当我按照上面描述的方式进行操作时,编译器会显示以下错误:
"不存在从"std::shared_ptr"到"void*"的合适转换函数"
_beginthreadex
看起来像c函数,为了实现您想要的,您需要调用复制构造函数(或者在unique_ptr
的情况下调用move)来转移所有权,这在c中是不可能的。
您可以考虑使用std::thread
类,它与std套件的其余部分配合得很好。
假设你想运行:
void ThreadStart(std::shared_ptr<TestClass> p);
你可以通过发射
void ThreadStart(std::shared_ptr<TestClass> p)
{
cout << p->count << " " << p->name << endl;
}
int main()
{
shared_ptr<TestClass> p = make_shared<TestClass>(33, "test");
std::thread thr(ThreadStart, p);
thr.join();
}
在std::unique_ptr
的情况下,您需要将其std::move
到线程函数,因此它实际上会在线程末尾被删除:
void ThreadStart(std::unique_ptr<TestClass> p);
...
unique_ptr<TestClass> p = make_unique<TestClass>(33, "test");
std::thread thr(ThreadStart, std::move(p));
使用shared_ptr::get
或unique_ptr::get
访问指向托管对象的指针。
shared_ptr<TestClass> p = make_shared<TestClass>(count, "test");
HANDLE hth1 = (HANDLE)_beginthreadex(NULL, 0, p->ThreadStart, p.get(), 0, NULL);
相关文章:
- CLANG 编译器 说:变量"PTR"可能未初始化
- 在以唯一ptr为值的C++映射中,动态内存何时会被销毁
- 将 ptr 传递给 ptr 到 A 作为参数传递给 A 的函数是不好的做法吗?
- 为共享 ptr 向量实现复制 c'tor?
- 字符和整数中 **(ptr+1) 的值差异
- C++:在不中断共享的情况下通过引用传递共享 PTR?
- 如何将派生类从基 ptr 分配给 nlohmann::json
- 引用 std::shared:ptr 以避免引用计数
- 为什么 beginthreadex 线程参数变量在父线程中没有更新
- 为什么我不能在不进行任何转换的情况下将浮点数放入任何类型的 ptr 中?
- 在调用函数时,ptr** 和 ptr*& 之间是否有区别,或者首选C++?
- 另一种类型的智能ptr,比如具有弱refs的unique_ptr
- 尝试打印出 *ptr++ 的值,以了解它是如何工作的
- 如何控制共享 ptr 引用计数?
- C++中的指针否定 (!ptr == NULL)
- 从const ptr*转换为ptr*时出现问题
- 这是MSVC 2013中具有共享PTR的单例的正确实现吗?
- 对唯一 ptr 无效读取的引用向量
- C++ 类型转换基础 PTR 到派生 PTR 保存在引用类中
- 如何使用非类型参数传递模板化类的 Ref 或 Ptr