C++ スマート ポインターは、動的メモリ管理を簡素化し、メモリ リークやダングリング ポインターを防ぎます。主なタイプは次のとおりです。 unique_ptr: 排他的所有権、スコープ外になった後にオブジェクトを解放します。 shared_ptr: 共有所有権。すべてのポインターがスコープ外に出た後、オブジェクトは解放されます。 weak_ptr: 所有権なし。ダングリング ポインタを防ぎます。例: unique_ptr: ポインタがスコープ外に出た後にオブジェクトを解放します。 shared_ptr: 複数のポインターが所有権を共有し、スコープ外に出た後にオブジェクトを解放します。 weak_ptr: 所有権がないため、オブジェクトを解放できません。実際のケース: 関数内でのメモリ リークを防ぐために、shared_ptr を使用します。
C++ では、動的メモリ管理は退屈でエラーが発生しやすいタスクです。スマート ポインタは、このタスクを簡素化し、メモリ リークやダングリング ポインタなどの一般的な問題を防ぐ軽量の参照型です。
C++ 標準ライブラリには、次の 3 つの主要なスマート ポインター タイプが用意されています。
unique_ptrの使用例:
int main() { unique_ptr<int> p(new int(5)); *p = 10; // p 是 p 所指向对象的唯一所有者,超出此范围后,对象将被释放。 }
shared_ptrの例:
int main() { shared_ptr<int> p(new int(5)); shared_ptr<int> q = p; // q 与 p 共享所有权 *p = 10; // p 和 q 都指向相同对象,当 p 和 q 都超出范围后,对象将被释放。 }
weak_ptrの例:
int main() { weak_ptr<int> p; { // 作用域开始 shared_ptr<int> q(new int(5)); p = q; // p 现在指向 q 所指向的对象 // 作用域结束 } // 即使 shared_ptr q 已经超出范围,weak_ptr p 仍然指向对象,但由于没有所有权,无法释放它。 }
次の例では、shared_ptr を使用して、メモリ リーク:
void read_file(istream& input) { // 在堆上分配一个流对象 ifstream* file_ptr = new ifstream(input.rdbuf()); // 现在可以使用文件流对象 // ... // 确保文件流在函数返回前被释放 delete file_ptr; }
この関数は、メモリ リークを防ぐためにスマート ポインタを使用して簡単に書き換えることができます:
void read_file(istream& input) { // shared_ptr 在函数返回时自动释放流对象 shared_ptr<ifstream> file_ptr(new ifstream(input.rdbuf())); // 现在可以使用文件流对象 // ... }
以上がC++ スマート ポインターはどのようにしてメモリ管理を簡素化するのでしょうか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。