バナーをクリックすれば目次に戻ります

Copyright 1999 Rogue Wave Software
Copyright 1999 Sun Microsystems, Inc.


rw_hashset

形式

#include <rw/rwstl/hashset.h>
rw_hashset<T,Hash,EQ> set;

説明

クラス rw_hashset<T,Hash,EQ> は、任意の T の複数のインスタンスが存在する可能性のないハッシュテーブルとして実装されている T のコレクションを維持します。これは値にもとづくコレクションであるため、オブジェクトはコレクションとの間でコピーされます。ANSI 関連コンテナ仕様に適合するすべてのクラス同様、rw_hashset はその要素を参照する反復子を提供します。rw_hashset の内容を変更する操作によって、コンテナを参照する他の反復子が無効になる可能性があります。rw_hashset の内容は擬似ランダム順になっているため、equal_range(key) を呼び出した結果だけが通常意味を持つ反復子範囲であり、全体の範囲は begin() から end() までです。

持続性

なし

公開 Typedef

typedef T                   key_type;
typedef T                   value_type; // または ... "const K"
typedef Hash                key_hash;
typedef EQ                  key_equal;
typedef (unsigned)          size_type; //rw_slist から
typedef (int)               difference_type; //rw_slist から
typedef (value_type&)       reference;
typedef (const value_type&) const_reference; //rw_slist から
rw_hashset<T,Hash,EQ> の反復子は順方向反復子です。

typedef (scoped Iterator)     iterator;
typedef (scoped ConsIterator) const_iterator;

公開コンストラクタ

rw_hashset<T,Hash,EQ>(size_type sz = 1024,
                      const Hash& h = Hash(),
                      const EQ& eq = EQ());

h をハッシュオブジェクトとして、eq を等値比較演算子として使用して、sz スロットを持つ空の rw_hashset<T,Hash,EQ> を作成します。

rw_hashset<T,Hash,EQ>(const rw_hashset<T,Hash,EQ>& set);

set のコピーである rw_hashset<T,Hash,EQ> を作成します。set から各要素が自分自身内にコピーされます。

rw_hashset<T,Hash,EQ>(const_iterator first,
                      const_iterator bound,
                      size_type sz=1024,
                      const Hash& h = Hash(),
                      const EQ& eq = EQ());

h をハッシュオブジェクトとして、eq を等値比較演算子として使用し、first で始まり bound で区切られる範囲で参照される各項目のコピーを収め、sz スロットを持つ rw_hashset<T,Hash,EQ> を作成します。

rw_hashset<T,Hash,EQ>(const value_type* first,
                      const value_type* bound,
                      size_type sz=1024,
                      const Hash& h = Hash(),
                      const EQ& eq = EQ());

h をハッシュオブジェクトとして、eq を等値比較演算子として使用し、first で始まり bound で区切られる範囲で参照される各項目のコピーを収め、sz スロットを持つ rw_hashset<T,Hash,EQ> を作成します。EQ をテストする範囲に項目がある場合は、そのような項目の最初の項目だけが自分自身内に挿入されます。

公開デストラクタ

~rw_hashset<T,Hash,EQ>();

デストラクタは、コンテナの実装で使用されていたメモリーを解放します。

公開演算子

rw_hashset<T,Hash,EQ>&
operator=(const rw_hashset<T,Hash,EQ>& rhs);

容量、HashEQrhs と同じになるように自分自身を設定し、自分自身の現在の内容をすべて削除して rhs 内の要素のコピーに置き換えます。

bool
operator==(const rw_hashset<T,Hash,EQ> & rhs) const;

自分自身と rhs の要素数が同じで、かつ自分自身内の各項目に EQ である rhs の項目がある場合は、TRUE を返します。

アクセサー関数

iterator
begin();

返される反復子は、自分自身内の最初の項目を参照します。自分自身が空の場合、反復子は end() に等しくなります。項目は擬似ランダム順に格納されているため、この反復子は自分自身内に格納されている項目をどれでも参照する可能性があるので注意してください。

const_iterator
begin() const;

返される反復子は、自分自身内の最初の項目を参照します。自分自身が空の場合、反復子は end() に等しくなります。項目は擬似ランダム順に格納されているため、この反復子は自分自身内に格納されている項目をどれでも参照する可能性があるので注意してください。

iterator
end();

返される反復子は、自分自身の「終端を越えた」位置にマークを付けます。間接参照できません。

const_iterator
end() const;

返される反復子は、自分自身の「終端を越えた」位置にマークを付けます。間接参照できません。

pair<const_iterator, const_iterator>
equal_range(const key_type key) const;

pair<const_iterator, const_iterator>(lower_bound(key), upper_bound(key)) を返します。上限と下限には、ハッシュにもとづくコレクションに対して特別な意味があります。該当する箇所を参照してください。

pair<iterator, iterator>
equal_range(const key_type key);

pair<iterator,iterator>(lower_bound(key), upper_bound(key)) を返します。上限と下限には、ハッシュにもとづくコレクションに対して特別な意味があります。該当する箇所を参照してください。

onst_iterator
lower_bound(const key_type& key) const;

自分自身内の key の下限を返します。これには、ハッシュにもとづくコレクションに対して特別な意味があります。該当する箇所を参照してください。

iterator
lower_bound(const key_type& key);

自分自身内の key の下限を返します。これには、ハッシュにもとづくコレクションに対して特別な意味があります。該当する箇所を参照してください。

const_iterator
upper_bound(const key_type& key) const;

自分自身内の key の上限を返します。これには、ハッシュにもとづくコレクションに対して特別な意味があります。該当する箇所を参照してください。

iterator
upper_bound(const key_type& key);

自分自身内の key の上限を返します。これには、ハッシュにもとづくコレクションに対して特別な意味があります。該当する箇所を参照してください。

Const 公開メンバー関数

size_type
capacity() const;

自分自身が使用するハッシュテーブル内のスロット数を返します。

bool
empty() const;

自分自身が空であれば TRUE を返します。

float
fill_ratio() const;

size()/capacity() の計算の結果を返します。

size_type
size() const;

自分自身が現在保持している項目数を返します。

変異子

void
clear();

erase(begin(),end()) の同義語です。

size_type
erase(const key_type& key);

key に等しい項目があれば、その項目は削除され、1 が返されます。それ以外の場合は 0 が返されます。

iterator
erase(iterator iter);

iter で参照される要素を削除し、「次の」要素を参照する反復子を返します。iter が自分自身内の項目を参照しない場合、結果は定義されていません。

iterator
erase(iterator first, iterator bound);

first で始まり bound で区切られる範囲の各要素を削除します。bound を参照する反復子を返します。first が自分自身内の項目を参照しない場合 (かつ firstbound が等しくない場合)、その影響は定義されていません。

pair<iterator,bool>
insert(const value_type& val);

自分自身内に val に等しい項目がない場合は val を挿入し、新しい要素を参照する反復子を持つペアと TRUE を返します。それ以外の場合、一致する value_type を参照する反復子を持つペアと FALSE を返します。

size_type
insert(iterator ignore, const value_type& val);

自分自身内に val に等しい項目がない場合は val を挿入し、1 を返します。それ以外の場合は何もしないで、0 を返します。最初の引数は ANSI 関連コンテナ仕様に適合させるためだけのもので、ハッシュテーブルの検索は一定時間で実行されるため、メソッドでは無視されます。

size_type
insert(const value_type* first, const value_type* bound);

first で始まり bound で区切られる範囲の各要素について、自分自身内に要素と等しい項目がない場合は、その要素が自分自身内にコピーされます。要素と等しい項目がある場合、その要素はスキップされます。挿入された要素数を返します。

size_type
insert(const_iterator first, const_iterator bound);

first で始まり bound で区切られる範囲の各要素について、自分自身内に要素と等しい項目がない場合は、その要素が自分自身内にコピーされます。要素と等しい項目がある場合、その要素はスキップされます。挿入された要素数を返します。

void
swap(rw_hashset<T,Hash,EQ>& other);

Hash オブジェクトと EQ オブジェクトを含め、other と自分自身の内容を交換します。このメソッドは、交換される項目をコピーしたり破壊するのではなく、基礎となるハッシュテーブルを交換します。

セットの特殊メソッド

size_type
count(const key_type& key) const;

自分自身内に key があれば 1 を返し、ない場合は 0 を返します。

const_iterator
find(const key_type& key) const;

key を参照する const_iterator が自分自身内にある場合はそれを返し、ない場合は end() を返します。

iterator
find(const key_type& key);

key を参照する反復子が自分自身内にある場合はそれを返し、ない場合は end() を返します。

void
resize(size_type sz);

sz スロットを持てるように、自分自身のハッシュテーブルのサイズを変更し、自分自身の要素をすべて、新しいテーブルにハッシュします。自分自身が保持している要素が多い場合は、大変時間がかかる可能性があります。