C++ 11 std::shared_ptr的总结与使用示例代码详解,能否详细阐述?

2026-04-19 00:172阅读0评论SEO基础
  • 内容介绍
  • 文章标签
  • 相关推荐

本文共计822个文字,预计阅读时间需要4分钟。

C++ 11 std::shared_ptr的总结与使用示例代码详解,能否详细阐述?

最近查看代码,发现智能指针使用较多。自己平时用的少,周末自己总结总结。方便后续继续使用。

+ std::shared_ptr 概括总结有以下几点:

(1)智能指针主要用途是方便资源的管理,自动释放没有的指针;(2)主要应用于资源管理,如动态分配的内存、文件句柄、网络连接等;(3)自动释放指针,避免内存泄漏。

最近看代码,智能指针用的比较多,自己平时用的少,周末自己总结总结。方便后续使用。

std::shared_ptr大概总结有以下几点:

(1) 智能指针主要的用途就是方便资源的管理,自动释放没有指针引用的资源。

(2) 使用引用计数来标识是否有多余指针指向该资源。(注意,shart_ptr本身指针会占1个引用)

(3) 在赋值操作中, 原来资源的引用计数会减一,新指向的资源引用计数会加一。

std::shared_ptr<Test> p1(new Test); std::shared_ptr<Test> p2(new Test); p1 = p2;

(4) 引用计数加一/减一操作是原子性的,所以线程安全的。

(5) make_shared要优于使用new,make_shared可以一次将需要内存分配好。

std::shared_ptr<Test> p = std::make_shared<Test>(); std::shared_ptr<Test> p(new Test);

(6)std::shared_ptr的大小是原始指针的两倍,因为它的内部有一个原始指针指向资源,同时有个指针指向引用计数。

(7) 引用计数是分配在动态分配的,std::shared_ptr支持拷贝,新的指针获可以获取前引用计数个数。

下面是一段示例代码,注释详细:

include <iostream> #include <memory> #include <thread> #include <chrono> #include <mutex> struct Test { Test() { std::cout << " Test::Test()\n"; } ~Test() { std::cout << " Test::~Test()\n"; } }; //线程函数 void thr(std::shared_ptr<Test> p) { //线程暂停1s std::this_thread::sleep_for(std::chrono::seconds(1)); //赋值操作, shared_ptr引用计数use_cont加1(c++11中是原子操作) std::shared_ptr<Test> lp = p; { //static变量(单例模式),多线程同步用 static std::mutex io_mutex; //std::lock_guard加锁 std::lock_guard<std::mutex> lk(io_mutex); std::cout << "local pointer in a thread:\n" << " lp.get() = " << lp.get() << ", lp.use_count() = " << lp.use_count() << '\n'; } } int main() { //使用make_shared一次分配好需要内存 std::shared_ptr<Test> p = std::make_shared<Test>(); //std::shared_ptr<Test> p(new Test); std::cout << "Created a shared Test\n" << " p.get() = " << p.get() << ", p.use_count() = " << p.use_count() << '\n'; //创建三个线程,t1,t2,t3 //形参作为拷贝, 引用计数也会加1 std::thread t1(thr, p), t2(thr, p), t3(thr, p); std::cout << "Shared ownership between 3 threads and released\n" << "ownership from main:\n" << " p.get() = " << p.get() << ", p.use_count() = " << p.use_count() << '\n'; //等待结束 t1.join(); t2.join(); t3.join(); std::cout << "All threads completed, the last one deleted\n"; return 0; }

编译执行:

C++ 11 std::shared_ptr的总结与使用示例代码详解,能否详细阐述?

参考:

c++实现加载so动态库中的资源 www.jb51.net/article/101744.htm

C++ 智能指针深入解析 www.jb51.net/article/39793.htm

C++11 智能指针之shared_ptr代码详解 www.jb51.net/article/188233.htm

总结

到此这篇关于C++11 std::shared_ptr总结与使用示例代码详解的文章就介绍到这了,更多相关C++11 std::shared_ptr内容请搜索自由互联以前的文章或继续浏览下面的相关文章希望大家以后多多支持自由互联!

本文共计822个文字,预计阅读时间需要4分钟。

C++ 11 std::shared_ptr的总结与使用示例代码详解,能否详细阐述?

最近查看代码,发现智能指针使用较多。自己平时用的少,周末自己总结总结。方便后续继续使用。

+ std::shared_ptr 概括总结有以下几点:

(1)智能指针主要用途是方便资源的管理,自动释放没有的指针;(2)主要应用于资源管理,如动态分配的内存、文件句柄、网络连接等;(3)自动释放指针,避免内存泄漏。

最近看代码,智能指针用的比较多,自己平时用的少,周末自己总结总结。方便后续使用。

std::shared_ptr大概总结有以下几点:

(1) 智能指针主要的用途就是方便资源的管理,自动释放没有指针引用的资源。

(2) 使用引用计数来标识是否有多余指针指向该资源。(注意,shart_ptr本身指针会占1个引用)

(3) 在赋值操作中, 原来资源的引用计数会减一,新指向的资源引用计数会加一。

std::shared_ptr<Test> p1(new Test); std::shared_ptr<Test> p2(new Test); p1 = p2;

(4) 引用计数加一/减一操作是原子性的,所以线程安全的。

(5) make_shared要优于使用new,make_shared可以一次将需要内存分配好。

std::shared_ptr<Test> p = std::make_shared<Test>(); std::shared_ptr<Test> p(new Test);

(6)std::shared_ptr的大小是原始指针的两倍,因为它的内部有一个原始指针指向资源,同时有个指针指向引用计数。

(7) 引用计数是分配在动态分配的,std::shared_ptr支持拷贝,新的指针获可以获取前引用计数个数。

下面是一段示例代码,注释详细:

include <iostream> #include <memory> #include <thread> #include <chrono> #include <mutex> struct Test { Test() { std::cout << " Test::Test()\n"; } ~Test() { std::cout << " Test::~Test()\n"; } }; //线程函数 void thr(std::shared_ptr<Test> p) { //线程暂停1s std::this_thread::sleep_for(std::chrono::seconds(1)); //赋值操作, shared_ptr引用计数use_cont加1(c++11中是原子操作) std::shared_ptr<Test> lp = p; { //static变量(单例模式),多线程同步用 static std::mutex io_mutex; //std::lock_guard加锁 std::lock_guard<std::mutex> lk(io_mutex); std::cout << "local pointer in a thread:\n" << " lp.get() = " << lp.get() << ", lp.use_count() = " << lp.use_count() << '\n'; } } int main() { //使用make_shared一次分配好需要内存 std::shared_ptr<Test> p = std::make_shared<Test>(); //std::shared_ptr<Test> p(new Test); std::cout << "Created a shared Test\n" << " p.get() = " << p.get() << ", p.use_count() = " << p.use_count() << '\n'; //创建三个线程,t1,t2,t3 //形参作为拷贝, 引用计数也会加1 std::thread t1(thr, p), t2(thr, p), t3(thr, p); std::cout << "Shared ownership between 3 threads and released\n" << "ownership from main:\n" << " p.get() = " << p.get() << ", p.use_count() = " << p.use_count() << '\n'; //等待结束 t1.join(); t2.join(); t3.join(); std::cout << "All threads completed, the last one deleted\n"; return 0; }

编译执行:

C++ 11 std::shared_ptr的总结与使用示例代码详解,能否详细阐述?

参考:

c++实现加载so动态库中的资源 www.jb51.net/article/101744.htm

C++ 智能指针深入解析 www.jb51.net/article/39793.htm

C++11 智能指针之shared_ptr代码详解 www.jb51.net/article/188233.htm

总结

到此这篇关于C++11 std::shared_ptr总结与使用示例代码详解的文章就介绍到这了,更多相关C++11 std::shared_ptr内容请搜索自由互联以前的文章或继续浏览下面的相关文章希望大家以后多多支持自由互联!