为什么不能通过裸指针创建shared_ptr对象
时间: 2024-10-01 07:03:56 浏览: 26
在C++中,`std::shared_ptr`是一种智能指针,用于管理动态分配的对象,并自动控制内存的释放。它内部有一个引用计数,每次`shared_ptr`增加对所指向对象的引用时,计数会加一;当引用计数降为零时,对象就会被销毁。
裸指针,即未包装在特定容器中的函数返回值或本地变量存储的指针,不具备引用计数的功能。如果直接尝试通过裸指针创建`shared_ptr`,`shared_ptr`无法跟踪有多少份引用存在,也就无法正确地管理对象的生命周期。因此,你需要通过`make_shared`工厂函数或者`shared_ptr`的构造函数来初始化,确保其能关联到正确的对象并开始计数。
以下是错误的做法:
```cpp
int* rawPointer = new int; // 裸指针
// 错误:这不会创建一个共享所有权的指针
std::shared_ptr<int> sharedBadly = rawPointer; // shared_ptr 没有正确关联对象
// 正确做法:
std::shared_ptr<int> sharedCorrectly = std::make_shared<int>(42); // 使用 make_shared 创建
```
相关问题
对c++中的smart pointer四个智能指针:shared_ptr,unique_ptr,weak_ptr,auto_ptr的理解
智能指针是C++中用于管理动态分配的内存的一种机制。它们可以自动地在不再需要时释放内存,从而避免内存泄漏和悬挂指针的问题。
shared_ptr是一种引用计数智能指针,它可以跟踪有多少个shared_ptr指向同一个对象,并在没有引用时自动释放内存。当创建shared_ptr时,它会增加引用计数,当销毁或重置shared_ptr时,它会减少引用计数。只有当引用计数为0时,才会真正释放内存。\[1\]shared_ptr可以通过构造函数接受一个指向动态分配对象的指针来创建,也可以使用std::make_shared函数来创建。\[2\]
unique_ptr是一种独占智能指针,它拥有对动态分配对象的唯一所有权。当unique_ptr被销毁时,它会自动释放内存。unique_ptr不能被复制,但可以通过std::move函数进行转移所有权。\[3\]unique_ptr可以通过构造函数接受一个指向动态分配对象的指针来创建。
weak_ptr是一种弱引用智能指针,它指向由shared_ptr管理的对象,但不会增加引用计数。weak_ptr可以用于解决shared_ptr的循环引用问题,因为它不会导致对象无法释放。\[1\]weak_ptr可以通过shared_ptr的构造函数来创建。
auto_ptr是C++11之前的一种智能指针,它类似于unique_ptr,但有一些限制和问题。auto_ptr在复制时会转移所有权,这可能导致悬挂指针的问题。因此,auto_ptr已经被unique_ptr取代,不推荐使用。
总结来说,shared_ptr是引用计数智能指针,unique_ptr是独占智能指针,weak_ptr是弱引用智能指针,而auto_ptr是已经过时的智能指针。它们各自有不同的用途和特点,可以根据具体的需求选择使用。
#### 引用[.reference_title]
- *1* *2* *3* [C++11 解决内存泄露问题的智能指针:shared_ptr、unique_ptr、weak_ptr](https://blog.csdn.net/weixin_44120785/article/details/128714630)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^control,239^v3^insert_chatgpt"}} ] [.reference_item]
[ .reference_list ]
shared_ptr先转weak_ptr再转shared_ptr,这两个shared_ptr是否是同一个
不是同一个,转换成weak_ptr后再转换成shared_ptr,会创建一个新的shared_ptr对象。这是因为weak_ptr是一种智能指针,它不会增加所指向对象的引用计数,因此需要再转换成shared_ptr时重新创建一个新的对象,并将引用计数加1。此时,两个shared_ptr对象所指向的内存地址相同,但它们是不同的对象。
阅读全文