次の方法で共有


set::empty と set::clear

Visual C++ で 設定 :: 空設定 :: クリア の標準テンプレート ライブラリ関数を使用する方法に (STL) ついて説明します。

template<class _K, class _Pr, class _A>
   class set
   {
      public:
      // Function 1:
      bool empty() const;
      // Function 2:
      void clear();
   }

解説

[!メモ]

プロトタイプのクラスやパラメーター名はヘッダー ファイルのバージョンと一致しない。ただし読みやすさが向上するように変更されました。

関数の戻り値は被制御シーケンスに要素がない場合調整します。 消去 (begin 終了 ) を呼び出して クリア の関数は被制御シーケンスのすべての要素を削除します。 消去 の関数の詳細については設定 :: 消去 を参照してください。

使用例

// SetEmptyClear.cpp
// compile with: /EHsc
//
//      Illustrates how to use the empty function to determine if
//      there are elements in the controlled sequence. It also
//      illustrates how to use the clear function to remove all
//      elements from the controlled sequence.
//
// Functions:
//
//    empty        Returns true if there are no elements in the
//                 controlled sequence.
//    clear        Removes all elements from the controlled sequence.
//////////////////////////////////////////////////////////////////////

#pragma warning(disable:4786)
#include <set>
#include <iostream>

using namespace std ;

typedef set<int> SET_INT;

void truefalse(int x)
{
  cout << (x?"True":"False") << endl;
}

int main() {
  SET_INT s1;

  cout << "s1.empty() returned ";
  truefalse(s1.empty());  // True

  cout << "s1.insert(5)" << endl;
  s1.insert(5);
  cout << "s1.insert(8)" << endl;
  s1.insert(8);

  cout << "s1.empty() returned ";
  truefalse(s1.empty());  // False

  cout << "s1.clear()" << endl;
  s1.clear();

  cout << "s1.empty() returned ";
  truefalse(s1.empty());  // True
}

出力

s1.empty() returned True
s1.insert(5)
s1.insert(8)
s1.empty() returned False
s1.clear()
s1.empty() returned True

必要条件

ヘッダー : <set>

参照

概念

標準テンプレート ライブラリのサンプル