Partager via


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

Voir aussi

Référence

istream_iterator Class

Modèles Standard