スマート ポインターは、ネイティブ ポインターのライフサイクルを管理し、C++ でよくあるメモリ リークの問題を回避するラッパー クラスです。一般的なタイプは次のとおりです: unique_ptr: 固有のオブジェクトを指すスマート ポインター。同時に所有者は 1 人だけであることを保証します。shared_ptr: 共有オブジェクトを指すスマート ポインター。複数の所有者を許可しますが、すべての所有者がオブジェクトの破棄を担当します。 ;weak_ptr: 共有オブジェクトを指すオブジェクトの参照カウントを増加させないスマート ポインター。
C++ スマート ポインターの魔法を明らかにしましょう: メモリ リークに別れを告げましょう
C++ プログラミングでは、メモリ リークは頭痛の種です。これにより、プログラムはますます多くのメモリを消費し、最終的にはクラッシュやパフォーマンスの低下につながります。スマート ポインターはこの問題を解決することを目的としており、堅牢でリークのないコードを作成するための鍵となります。
スマート ポインターの仕組み
スマート ポインターは、ネイティブ ポインター (int*
など) をカプセル化するコンテナー クラスです。ポインタのライフサイクル管理を担当し、ポイントされたメモリが不要になったときに自動的に解放します。 int*
) 的容器类。它负责指针的生命周期管理,自动在不再需要时释放指向的内存。
常见的智能指针类型
实战案例
假设我们有一个 Foo
一般的なスマート ポインターの種類
: 固有のオブジェクトを指すスマート ポインター。一度に所有者が 1 人だけであることを確認してください。
: 共有オブジェクトを指すスマート ポインター。複数の所有者が許可されますが、すべての所有者がオブジェクトを破棄する責任があります。
実際的なケース
Foo
クラスがあるとします:
class Foo { public: Foo() { cout << "Foo constructed\n"; } ~Foo() { cout << "Foo destructed\n"; } };
例 1: 生のポインターの使用
スマート ポインターを使用しない場合は、 raw ポインターの管理ではエラーが発生しやすく、メモリ リークが発生します:
Foo* foo = new Foo(); // 创建 Foo 对象 // ... 使用 foo 对象 ... delete foo; // 记得释放内存,否则会泄漏 // ...
例 2: スマート ポインター (unique_ptr) の使用
🎜🎜 unique_ptr を使用すると、スマート ポインターはオブジェクトを破棄し、リークを回避する責任があります: 🎜unique_ptr<Foo> foo(new Foo()); // 创建 Foo 对象,自动释放 // ... 使用 foo 对象 ... // foo 超出作用域时,自动销毁 Foo 对象
shared_ptr<Foo> foo(new Foo()); // 创建 Foo 对象,按引用计数释放 shared_ptr<Foo> bar = foo; // 创建另一个指向同一 Foo 对象的指针 // ... 使用 foo 和 bar 对象 ... // 最后一个 bar 超出作用域时,Foo 对象销毁
以上がC++ スマート ポインタの魔法を明らかにする: メモリ リークを防ぐ方法の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。