バナーをクリックすれば目次に戻ります
Copyright 1999 Rogue Wave Software
Copyright 1999 Sun Microsystems, Inc.
RWTPtrHashMapIterator<K,T,H,EQ>
#include<rw/tphdict.h> RWTPtrHashMap<K,T,H,EQ> m; RWTPtrHashMap<K,T,H,EQ> itr(m);
注 - 標準 C++ ライブラリがある場合は、ここで述べるインタフェースを使用します。標準 C++ ライブラリがない場合は、付録 A に記載する RWTPtrHashDictionaryIterator 用インタフェースを使用してください。
RWTPtrHashMap に対する繰り返しは擬似ランダムであり、基礎となるハッシュテーブルの容量と使用するハッシュ関数によって決まります。
この反復子が参照する現在の項目は、作成後も、reset() の呼び出し後も定義されていません。反復子は、前置インクリメントか operator() を用いて進められた後に有効になります。
operator++ と operator() の場合は、最後の要素を越えて反復すると、ブール型の FALSE に相当する値を返します。一度この状態に達してからも増分し続けると、reset() が呼び出されるまで、FALSE に相当する値を返します。
#include<rw/tphdict.h> #include<iostream.h> #include<rw/cstring.h> struct silly_h{ unsigned long operator()(RWCString x) const { return x.length() * (long)x(0); } }; int main(){ RWTPtrHashMap <RWCString,int,silly_h,equal_to<RWCString> > age; RWTPtrHashMapIterator <RWCString,int,silly_h,equal_to<RWCString> > itr(age); age.insert(new RWCString("John"),new int(30)); age.insert(new RWCString("Steve"),new int(17)); age.insert(new RWCString("Mark"),new int(24)); // 二重挿入が拒絶された age.insert(new RWCString("Steve"),new int(24)); for(;++itr;) cout << *itr.key() << "\'s age is " << *itr.value() << endl; return 0; } |
John's age is 30 Mark's age is 24 Steve's age is 17 |
RWTPtrHashMapIterator<K,T,H,EQ>(RWTPtrHashMap<K,T,H,EQ>&h);
K* operator()();
RWBoolean operator++();
RWTPtrHashMap<K,T,H,EQ>* container() const;
K* key() const;
void reset(); void reset(RWTPtrHashMap<K,T,H,EQ>& h);
T* value();