istream_iterator::istream_iterator
Construit un itérateur de fin de flux comme istream_iterator par défaut ou un istream_iterator initialisé au type du flux de l'itérateur duquel il lit.
istream_iterator( );
istream_iterator(
istream_type& _Istr
);
Paramètres
- _Istr
Le flux d'entrée à être lue utilisation d'initialiser istream_iterator.
Notes
Le premier constructeur initialise le pointeur de flux d'entrée à un pointeur null et crée un itérateur de fin de flux.Le deuxième constructeur initialise le pointeur de flux d'entrée avec le &_Istr, puis tente de récupérer et stocker un objet de type Type.
L'itérateur de fin de flux peut être utilisation de tester si istream_iterator a atteint la fin d'un flux.
Exemple
// istream_iterator_istream_iterator.cpp
// compile with: /EHsc
#include <iterator>
#include <vector>
#include <algorithm>
#include <iostream>
int main( )
{
using namespace std;
// Used in conjunction with copy algorithm
// to put elements into a vector read from cin
vector<int> vec ( 4 );
vector <int>::iterator Iter;
cout << "Enter 4 integers separated by spaces & then\n"
<< " a character ( try example: '2 4 6 8 a' ): ";
istream_iterator<int> intvecRead ( cin );
// Default constructor will test equal to end of stream
// for delimiting source range of vecor
copy ( intvecRead , istream_iterator<int>( ) , vec.begin ( ) );
cin.clear ( );
cout << "vec = ";
for ( Iter = vec.begin( ) ; Iter != vec.end( ) ; Iter++ )
cout << *Iter << " "; cout << endl;
}
2 4 6 8 a
2 4 6 8 a Entrez 4 entiers séparés par des espaces puis un caractère (exemple de test : « 2 4 6 8 a ") : 2 4 6 8 un vec = 2 4 6 8
Configuration requise
en-tête : <iterator>
l'espace de noms : DST