C++ åèæå
- C++11
- C++14
- C++17
- C++20
- C++ ç¼è¯å¨æ¯ææ åµè¡¨
- ç¬ç«ä¸å®¿ä¸»å®ç°
- C++ è¯è¨
- C++ å ³é®è¯
- é¢å¤çå¨
- C++ æ ååºå¤´æä»¶
- å ·åè¦æ±
- åè½ç¹æ§æµè¯ (C++20)
- å·¥å ·åº
- ç±»åæ¯æï¼åºæ¬ç±»åãRTTIãç±»åç¹æ§ï¼
- æ¦å¿µåº (C++20)
- é误å¤ç
- 卿å å管ç
- std::unique_ptr
- std::scoped_allocator_adaptor
- std::auto_ptr
- std::destroy_at
- std::destroy
- std::destroy_n
- std::uninitialized_move
- std::uninitialized_value_construct
- std::owner_less
- std::shared_ptr
- std::allocate_shared, std::allocate_shared_for_overwrite
- std::make_shared, std::make_shared_for_overwrite
- std::atomic(std::shared_ptr)
- std::hash(std::shared_ptr)
- std::atomic_...<std::shared_ptr>
- std::addressof
- std::allocator_traits
- std::default_delete
- std::allocator_arg_t
- std::allocator_arg
- std::weak_ptr
- std::enable_shared_from_this
- std::bad_weak_ptr
- std::to_address
- std::assume_aligned
- std::make_obj_using_allocator
- C å å管çåº
- ä½å±å å管ç
- std::pmr::memory_resource
- std::allocator
- std::pointer_traits
- std::uses_allocator
- std::uses_allocator_construction_args
- std::uninitialized_construct_using_allocator
- std::pmr::polymorphic_allocator
- std::pmr::get_default_resource
- std::pmr::set_default_resource
- std::pmr::new_delete_resource
- std::pmr::null_memory_resource
- std::pmr::synchronized_pool_resource
- std::pmr::unsynchronized_pool_resource
- std::pmr::monotonic_buffer_resource
- std::pmr::pool_options
- std::raw_storage_iterator
- std::get_temporary_buffer
- std::return_temporary_buffer
- std::uninitialized_copy
- std::uninitialized_fill
- std::uninitialized_default_construct
- std::uninitialized_copy_n
- std::uninitialized_fill_n
- std::uninitialized_move_n
- std::uninitialized_default_construct_n
- std::uninitialized_value_construct_n
- std::construct_at
- std::align
- 注é
- æ¥æåæ¶é´å·¥å ·
- å符串åº
- 容å¨åº
- è¿ä»£å¨åº
- èå´åº (C++20)
- ç®æ³åº
- æ°å¼åº
- è¾å ¥/è¾åºåº
- æä»¶ç³»ç»åº
- æ¬å°ååº
- æ£å表达å¼åº
- ååæä½åº
- çº¿ç¨æ¯æåº
- å®éªæ§ C++ ç¹æ§
- æç¨çèµæº
- ç´¢å¼
- std 符å·ç´¢å¼
- åç¨æ¯æ (C++20)
- C++ å ³é®è¯
ä½ç½®ï¼é¦é¡µ > C++ åèæå >卿å å管ç >std::shared_ptr > std::make_shared, std::make_shared_for_overwrite
std::make_shared, std::make_shared_for_overwrite
| å®ä¹äºå¤´æä»¶ <memory>
|
||
| template< class T, class... Args > shared_ptr<T> make_shared( Args&&... args ); |
(1) | (C++11 èµ·) (T éæ°ç») |
| template<class T> shared_ptr<T> make_shared( std::size_t N ); |
(2) | (C++20 起) (T 为 U[]) |
| template<class T> shared_ptr<T> make_shared(); |
(3) | (C++20 起) (T 为 U[N]) |
| template<class T> shared_ptr<T> make_shared( std::size_t N, const std::remove_extent_t<T>& u ); |
(4) | (C++20 起) (T 为 U[]) |
| template<class T> shared_ptr<T> make_shared( const std::remove_extent_t<T>& u ); |
(5) | (C++20 起) (T 为 U[N]) |
| template<class T> shared_ptr<T> make_shared_for_overwrite(); |
(6) | (C++20 èµ·) (T é U[]) |
| template<class T> shared_ptr<T> make_shared_for_overwrite( std::size_t N ); |
(7) | (C++20 起) (T 为 U[]) |
args 为 T çæé 彿°åæ°åè¡¨ï¼æé T ç±»å对象并å°å®å
è£
äº std::shared_ptr ã对象å¦åç¨è¡¨è¾¾å¼ ::new (pv) T(std::forward<Args>(args)...) æé ï¼å
¶ä¸ pv æ¯å
鍿åéåä¿æ T ç±»å对象çåå¨ç void* æéãåå¨å
¸åå°å¤§äº sizeof(T) ï¼ä»¥å¯¹å
±äº«æéæ§å¶åå T 对象使ç¨ä¸æ¬¡åé
ãæ¤å½æ°æè°ç¨ç std::shared_ptr æé 彿°ä»¥æåæ°æé ç T ç±»å对象æéå¯ç¨ shared_from_this ãæ¤éè½½ä»
è¥ T 䏿¯æ°ç»ç±»åæåä¸éè½½å³è®®ãstd::remove_all_extents_t<T> ç±»åçéæ°ç»å
ç´ å¦å以å¸ç½® new è¡¨è¾¾å¼ ::new(pv) std::remove_all_extents_t<T>() å¼åå§åãéè½½ (2) å建第ä¸ç»´ä¸å¤§å°ä¸º N çæ°ç»ãæ°ç»å
ç´ ä»¥å
¶å°åéå¢é¡ºåºåå§åï¼èå½å
¶çåæç»ææ¶ï¼ä»¥åæ¬æé 顺åºçéåºéæ¯ãu åå§åãè¥ U 䏿¯æ°ç»ç±»åï¼åè¿å¦åä»¥å¦ (1) ä¸çå¸ç½® new 表达å¼è¿è¡ï¼å¦åï¼è¿å¦å以å¦å (1) ä¸çå¸ç½® new 表达å¼ï¼ä»æ¥èª u ç对åºå
ç´ åå§åï¼å¯è½å¤ç»´çï¼æ°ç»çæ¯ä¸ªéæ°ç»å
ç´ ãéè½½ (4) å建第ä¸ç»´ä¸å¤§å°ä¸º N çæ°ç»ãæ°ç»å
ç´ ä»¥å
¶å°åéå¢é¡ºåºåå§åï¼èå½å
¶çåæç»ææ¶ï¼ä»¥åæ¬æé 顺åºçéåºéæ¯ãT 䏿¯æ°ç»ç±»ååå (1) ï¼èè¥ (3) æ¯ U[N] åå if T ï¼é¤äºé»è®¤åå§åå建çå¯¹è±¡ãæ¯ç§æ
åµä¸ï¼åå°ç¨ p->~X() éæ¯å¯¹è±¡ï¼æè¥ T 为æ°ç»ç±»åå为åç¬çå
ç´ ï¼ (C++20 èµ·)ï¼å
¶ä¸ p æ¯æå对象çæéï¼è X æ¯è¯¥å¯¹è±¡çç±»åã
åæ°
| args | - | å°ç¨ä»¥æé T å®ä¾çåæ°å表ã
|
| N | - | è¦ä½¿ç¨çæ°ç» |
| u | - | åå§åæ°ç»æ¯ä¸ªå ç´ çåå¼ |
è¿åå¼
ç±»å T å®ä¾ç std::shared_ptr ã
å¼å¸¸
å¯è½æåº std::bad_alloc æä»»ä½ T æé 彿°ææçå¼å¸¸ãè¥æåºå¼å¸¸ï¼å彿°æ ææãè¥å¼å¸¸å¨æ°ç»çæé 䏿åºï¼åå·²åå§åå
ç´ ä»¥éåºéæ¯ã (C++20 èµ·)
注解
æ¤å½æ°å¯ç¨ä½ std::shared_ptr<T>(new T(args...)) çæ¿ä»£åãå¾å¤±æ¯ï¼
- std::shared_ptr<T>(new T(args...)) è¿è¡è³å°äºæ¬¡åé
ï¼ä¸æ¬¡ä¸º
Tèå¦ä¸æ¬¡ä¸ºå ±äº«æéçæ§å¶åï¼ï¼è std::make_shared<T> å ¸åå°ä» è¿è¡ä¸æ¬¡åé ï¼æ 忍èä½ä¸è¦æ±å¦æ¤ï¼ææå·²ç¥å®ç°å妿¤ï¼ã - è¥ä»»ä½ std::weak_ptr 卿æå
±äº«æ¥æè
ççåæç»æåå¼ç¨
std::make_sharedæåå»ºçæ§å¶åï¼åTæå æçå åç»´æçï¼ç´è³ææå¼±æ¥æè äº¦è¢«éæ¯ï¼è¥sizeof(T)è¾å¤§åè¿å¯è½æ¯ä¸æ³è¦çã - std::shared_ptr<T>(new T(args...)) å¯è½è°ç¨
Tçéå ¬å¼æé 彿°ï¼è¥å¨å®å¯è®¿é®çè¯å¢ä¸æ§è¡ï¼èstd::make_sharedè¦æ±å¯¹è¢«éæ©æé 彿°çå ¬å¼è®¿é®ã - ä¸åäº std::shared_ptr æé 彿°ï¼
std::make_sharedä¸å 许èªå®ä¹å é¤å¨ã -
std::make_sharedä½¿ç¨ ::new ï¼æ è¥ç¨ç±»ç¹å®ç operator new 设置äºä»»ä½ç¹æ®è¡ä¸ºï¼åå®å°å¼äº std::shared_ptr<T>(new T(args...)) ã
|
(C++20 å) |
|
(C++17 å) |
æé 彿°ä»¥ U* ç±»åæé ptr å¯ç¨ shared_from_this ï¼è¡¨ç¤ºå®ç¡®å® U æ¯å¦æ¥æä½ä¸º std::enable_shared_from_this ç¹åçæ æ§ä¹ä¸å¯è®¿é® (C++17 èµ·)åºç±»ï¼èè¥å¦æ¤ï¼åæé 彿°æ±å¼è¯¥è¯å¥ï¼
if (ptr != nullptr && ptr->weak_this.expired()) ptr->weak_this = std::shared_ptr<std::remove_cv_t<U>>(*this, const_cast<std::remove_cv_t<U>*>(ptr));
å
¶ä¸ weak_this æ¯ std::shared_from_this çéè mutable std::weak_ptr æåã对 weak_this æåçèµå¼ä¸æ¯ååçï¼ä¸ä¸ä»»ä½å°åä¸å¯¹è±¡çæ½å¨å¹¶å访é®å²çªãè¿ç¡®ä¿å°æ¥å¯¹ shared_from_this() è°ç¨ï¼å°ä¸æ¤è£¸æéæé 彿°æå建ç shared_ptr å
±äº«æææã
ä¸è¿°è§£é代ç ä¸ï¼æµè¯ ptr->weak_this.expired() æ¯ä¸ºç¡®ä¿è¥ weak_this æç¤ºå·²æå æè
åéèµå¼å®ãä» C++17 èµ·è¦æ±æ¤æµè¯ã
示ä¾
#include <iostream> #include <memory> #include <type_traits>  struct C { C(int i) : i(i) {} // < éè¦æé 彿° (C++20 å) int i; };  int main() { auto sp = std::make_shared<C>(12);  static_assert(std::is_same_v<decltype(sp), std::shared_ptr<C>>);  std::cout << sp->i << '\n'; }
è¾åºï¼
12
åé
æé æ°ç shared_ptr (å ¬å¼æå彿°) | |
| å建管çä¸ä¸ªç¨åé
å¨åé
çæ°å¯¹è±¡çå
±äº«æé (彿°æ¨¡æ¿) | |
| (C++14)(C++20) |
å建管çä¸ä¸ªæ°å¯¹è±¡çç¬å æé (彿°æ¨¡æ¿) |
| åé
彿° (彿°) |