 
 
|  |  | 
| Category: iterators | Component type: type | 
class my_random_access_iterator : public random_access_iterator<double> 
{
  ...
};
This declares my_random_access_iterator to be a Random Access Iterator whose
value type is double and whose distance type is ptrdiff_t.  
If Iter is an object of class my_random_access_iterator, then
iterator_category(Iter) will return random_access_iterator_tag(),
value_type(Iter) will return (double*) 0, and distance_type(Iter)
will return (ptrdiff_t*) 0.
| Parameter | Description | Default | 
|---|---|---|
| T | The iterator's value type | |
| Distance | The iterator's distance type | ptrdiff_t | 
[1] It is not required that a Random Access Iterator inherit from the base random_access_iterator. It is, however, required that the functions iterator_category, distance_type, and value_type be defined for every Random Access Iterator. (Or, if you are using the iterator_traits mechanism, that iterator_traits is properly specialized for every Random Access Iterator.) Since those functions are defined for the base random_access_iterator, the easiest way to ensure that are defined for a new type is to derive that class from random_access_iterator and rely on the derived-to-base standard conversion of function arguments.
![[Silicon Surf]](surf.gif) 
![[STL Home]](stl_home.gif)