C++ で STL コンテナをクリアするには、次の 3 つのメソッドを使用できます。 コンテナ内のすべての要素を直接クリアするには、clear() メソッドを使用します。 Erase() または Pop_back() メソッドを使用して、コンテナ内のすべての要素を 1 つずつ削除します。ステートフル コンテナ クラス (ShoppingCart など) の場合、カスタムの clear() メソッドを提供してその内容をクリアできます。
C++ STL コンテナをクリアする方法
C++ では、標準テンプレート ライブラリ (STL) が、ベクトル、リンク リスト、セットなどの強力なコンテナ クラスを提供します。これらのコンテナーはデータを保存および管理するように設計されており、さまざまなプログラミング シナリオで役立ちます。ただし、場合によっては、コンテナーの内容をクリアする必要がある場合があります。
1. clear() コンテナ メソッド
最も簡単で直接的な方法は、clear()
メソッドを使用することです。このメソッドは、コンテナーからすべての要素を削除し、空のコンテナーにします。 clear()
方法。该方法从容器中删除所有元素,使其变为空容器。
#include <vector> int main() { std::vector<int> numbers = {1, 2, 3, 4, 5}; // 使用 clear() 方法清除容器 numbers.clear(); // 检查容器是否为空 if (numbers.empty()) { std::cout << "容器已清除" << std::endl; } return 0; }
2. 删除所有元素:erase() 或 pop_back()
另一种清除容器内容的方法是删除所有元素。对于向量和链表,可以使用 erase()
方法。它接受一个范围作为参数,并删除指定范围内的所有元素。
对于栈和队列,可以使用 pop_back()
#include <list> int main() { std::list<int> numbers = {1, 2, 3, 4, 5}; // 删除所有元素:erase() 方法 numbers.erase(numbers.begin(), numbers.end()); // 检查容器是否为空 if (numbers.empty()) { std::cout << "容器已清除" << std::endl; } return 0; }
2. すべての要素を削除します: Erase() または Pop_back()
コンテナの内容をクリアするもう 1 つの方法は、すべての要素を削除することです。ベクトルとリンク リストの場合は、erase()
メソッドを使用できます。引数として範囲を受け取り、指定された範囲内のすべての要素を削除します。 スタックとキューの場合、(コンテナが空でない場合) pop_back()
メソッドを使用して、コンテナが空になるまで最後の要素を削除できます。 🎜#include <vector> class Product { public: std::string name; int quantity; }; class ShoppingCart { public: std::vector<Product> products; // 清除购物车 void clear() { products.clear(); } }; int main() { ShoppingCart cart; // 添加一些产品到购物车 cart.products.push_back({ "苹果", 5 }); cart.products.push_back({ "香蕉", 3 }); // 完成购物,清除购物车 cart.clear(); // 检查购物车是否为空 if (cart.products.empty()) { std::cout << "购物车已清除" << std::endl; } return 0; }
以上がC++ STL コンテナをクリアするにはどうすればよいですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。