Rogue Wave Software logo banner

Click on the banner to return to the Class Reference home page.

©Copyright 1996 Rogue Wave Software

RWTPtrMapIterator<K,T,C>

Synopsis

#include<rw/tpmap.h>
RWTPMap<K,T,C> map;
RWTPMapIterator<K,T,C> itr(map);

Standard C++ Library Dependent!


RWTPtrMapIterator requires the Standard C++ Library.



Description

RWTPrtMapIterator is supplied with Tools 7 to provide an iterator interface to the new Standard Library based collections that has backward compatibility with the container iterators provided in Tools 6.

The order of iteration over an RWTPtrMap is dependent on the comparator object supplied as applied to the key values of the stored associations.

The current item referenced by this iterator is undefined after construction or after a call to reset(). The iterator becomes valid after being advanced with either a preincrement or operator().

For both operator++ and operator(), iterating past the last element will return a value equivalent to boolean false. Continued increments will return a value equivalent to false until reset() is called.

Persistence

None

Examples

#include<rw/tpmap.h>
#include<iostream.h>
#include<rw/cstring.h>

int main(){
   RWTPtrMap<RWCString,int,less<RWCString> > age;
   RWTPtrMapIterator<RWCString,int,less<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));
//Insertion is rejected, no duplicates allowed
   age.insert(new RWCString("Steve"),new int(24));
for(;itr();)
     cout << *itr.key() << "\'s age is " << *itr.value() << endl;
   return 0;
}
Program Output
John's age is 30
Mark's age is 24
Steve's age is 17

Public Constructors

RWTPtrMapIterator<K,T,C>(const RWTPtrMap<K,T,C>& rwm);

Public Member Operators

K*
operator()();
RWBoolean
operator++();

Public Member Functions

RWTPtrMap<K,T,C>*
container() const;
K*
key() const;
void
reset();
void
reset(RWTPtrMap<K,T,C>& h);
T*
value();