shared_ptr demo

本文深入探讨了C++中智能指针的实现机制,特别是shared_ptr的共享计数原理,通过实例展示了如何在实际编程中利用智能指针提高代码的内存管理效率,避免了传统指针可能引发的内存泄漏问题。
#include <iostream>
#include <memory>

using namespace std;

int main()
{
    shared_ptr<int> p = make_shared<int>(10);
    cout << *p << endl;

    auto q(p);
    *q = 100;

    cout << *p << " " << *q << endl;
    cout << "count == " << p.use_count() << endl;

    return 0;
}

好的,以下是一个简单的示例代码,演示如何使用 `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` 结构体,因此需要手动释放它,以避免内存泄漏。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值