pthread_create + shared_ptr demo ,通过 pthread_create 传递给新创建的子线程
时间: 2023-07-08 11:49:39 浏览: 154
pthread示例demo
好的,以下是一个简单的示例代码,演示如何使用 `pthread_create` 传递 `shared_ptr` 给子线程:
```c++
#include <iostream>
#include <pthread.h>
#include <memory>
using namespace std;
struct ThreadData {
shared_ptr<int> ptr;
};
void* ThreadFunc(void* data) {
auto threadData = static_cast<ThreadData*>(data);
cout << "Thread: " << pthread_self() << " get shared_ptr value: " << *(threadData->ptr) << endl;
return nullptr;
}
int main() {
auto ptr = make_shared<int>(42);
ThreadData data {ptr};
pthread_t thread;
pthread_create(&thread, nullptr, ThreadFunc, &data);
pthread_join(thread, nullptr);
return 0;
}
```
在这个示例代码中,我们首先创建了一个 `shared_ptr<int>`,并将其值设置为 42。然后,我们创建了一个 `ThreadData` 结构体,包含一个 `shared_ptr<int>`,并将前面创建的 `shared_ptr<int>` 设置为这个结构体中的成员。接着,我们使用 `pthread_create` 创建了一个新的线程,并将 `ThreadData` 结构体的地址传递给线程的入口函数 `ThreadFunc`。在这个函数中,我们将 `ThreadData` 指针转换为真实的类型,并输出 `shared_ptr<int>` 中的值。最后,我们使用 `pthread_join` 等待线程结束。
需要注意的是,由于 `shared_ptr` 是引用计数的智能指针,我们不需要手动释放它,当引用计数为 0 时,它会自动释放。在这个示例代码中,当线程结束时,它不会释放 `ThreadData` 结构体,因此需要手动释放它,以避免内存泄漏。
阅读全文