GSP
Quick Navigator

Search Site

Unix VPS
A - Starter
B - Basic
C - Preferred
D - Commercial
MPS - Dedicated
Previous VPSs
* Sign Up! *

Support
Contact Us
Online Help
Handbooks
Domain Status
Man Pages

FAQ
Virtual Servers
Pricing
Billing
Technical

Network
Facilities
Connectivity
Topology Map

Miscellaneous
Server Agreement
Year 2038
Credits
 

USA Flag

 

 

Man Pages
std::istreambuf_iterator(3) C++ Standard Libary std::istreambuf_iterator(3)

std::istreambuf_iterator - std::istreambuf_iterator


Defined in header <iterator>
template< class CharT, class Traits = std::char_traits<CharT> >


class istreambuf_iterator : public std::iterator<
std::input_iterator_tag,
CharT, (until C++17)
typename Traits::off_type,
/* unspecified, usually CharT* */,


CharT >
template< class CharT, class Traits = std::char_traits<CharT> > (since C++17)
class istreambuf_iterator;


std::istreambuf_iterator is a single-pass input iterator that reads successive
characters from the std::basic_streambuf object for which it was constructed.


The default-constructed std::istreambuf_iterator is known as the end-of-stream
iterator. When a valid std::istreambuf_iterator reaches the end of the underlying
stream, it becomes equal to the end-of-stream iterator. Dereferencing or
incrementing it further invokes undefined behavior.


std::istreambuf_iterator has a trivial copy constructor, a constexpr (since C++11)
default constructor, and a trivial destructor.


Member type Definition
iterator_category std::input_iterator_tag
value_type CharT
difference_type Traits::off_type
pointer /* unspecified, usually CharT* */
reference CharT
char_type CharT
traits_type Traits
int_type typename traits::int_type
streambuf_type std::basic_streambuf<CharT, Traits>
istream_type std::basic_istream<CharT, Traits>
Implementation-defined class type. The name proxy is for
exposition only.
/* proxy */ A proxy object holds a char_type character and a streambuf_type*
pointer.
Deferencing a proxy object with operator* yields the stored
character.


Member types iterator_category, value_type, difference_type, pointer
and reference are required to be obtained by inheriting from (until C++17)
std::iterator<std::input_iterator_tag, CharT, Traits::off_type, /*
unspecified, usually CharT* */, CharT>.


constructor constructs a new istreambuf_iterator
(public member function)
destructor destructs an istreambuf_iterator
(implicitly declared) (public member function)
operator* obtains a copy of the current character
operator-> accesses a member of the current character, if CharT has
(since C++11)(until C++17) members
(public member function)
operator++ advances the iterator
operator++(int) (public member function)
tests if both istreambuf_iterators are end-of-stream or
equal if both are valid
(public member function)


operator== compares two istreambuf_iterators
operator!= (function template)
(removed in C++20)

// Run this code


#include <string>
#include <sstream>
#include <iostream>
#include <iterator>


int main()
{
// typical use case: an input stream represented as a pair of iterators
std::istringstream in{"Hello, world"};
std::istreambuf_iterator<char> it{in}, end;
std::string ss{it, end};
std::cout << "ss has " << ss.size() << " bytes; "
"it holds \"" << ss << "\"\n";


// demonstration of the single-pass nature
std::istringstream s{"abc"};
std::istreambuf_iterator<char> i1{s}, i2{s};
std::cout << "i1 returns '" << *i1 << "'\n"
"i2 returns '" << *i2 << "'\n";
++i1;
std::cout << "after incrementing i1, but not i2\n"
"i1 returns '" << *i1 << "'\n"
"i2 returns '" << *i2 << "'\n";
++i2;
std::cout << "after incrementing i2, but not i1\n"
"i1 returns '" << *i1 << "'\n"
"i2 returns '" << *i2 << "'\n";
}


ss has 12 bytes; it holds "Hello, world"
i1 returns 'a'
i2 returns 'a'
after incrementing i1, but not i2
i1 returns 'b'
i2 returns 'b'
after incrementing i2, but not i1
i1 returns 'c'
i2 returns 'c'


ostreambuf_iterator output iterator that writes to std::basic_streambuf
(class template)
istream_iterator input iterator that reads from std::basic_istream
(class template)

2022.07.31 http://cppreference.com

Search for    or go to Top of page |  Section 3 |  Main Index

Powered by GSP Visit the GSP FreeBSD Man Page Interface.
Output converted with ManDoc.