C STL 流迭代器

2022-09-03 15:21:19 字數 2064 閱讀 9564

流迭代器是一種迭代器介面卡。istream_iterator用於讀取輸入流,ostream_iterator用於寫輸出流。這些迭代器將它們所對應的流視為特定型別的元素序列。使用流迭代器時,可以用泛型演算法從流物件中讀資料或將資料寫入到流物件中。

流迭代器的建構函式如下:

流迭代器的基本操作如下:

1、流迭代器的定義。

流迭代器都是類模板:任何已定義輸入操作符(>>操作符)的型別都可以定義istream_iterator,任何已定義輸出操作符(《操作符)的型別都可以定義ostream_iterator。

istream_iteratorcin_it(cin);            //從cin讀取int型資料

istream_iteratorend_of_stream;            //指向超出末端位置

ofstream outfile;

ostream_iteratoroutput(outfile, " ");

注意:(1)在建立流迭代器時,必須指定迭代器所讀寫的物件型別。

(2)ostream_iterator不提供超出末端迭代器。

(3)建立ostream_iterator物件時,可提供第二個(可選的)實參,指定將元素寫入輸出流時使用的分隔符。分隔符必須是c風格字串,所以必須以空字元結束,否則其行為是未定義的。

2、istream_iterator物件上的操作。

提供了輸入操作符(>>)的任何型別都可以建立istream_iterator物件。構造與流繫結在一起的istream_iterator物件時,將對迭代器定位到第乙個值。下面有兩段程式是等價的:

/*程式1*/

istream_iteratorin_iter(cin);

istream_iteratoreof;

vectorvec;

while (in_iter != eof)

/*程式2*/

istream_iteratorin_iter1(cin);

istream_iteratoreof1;

vectorvec(in_iter1, eof1);

程式1從cin中讀取int型資料,並將讀入的內容儲存到vec中。當輸入非int型數值或到達檔案結束停止。程式2用一對標記元素範圍的迭代器構造vec物件,效果與程式1相同。

3、ostream_iterator物件上的操作。

可用ostream_iterator物件將乙個值序列寫入流中。

ostream_iteratorout_iter(cout, "\n");

istream_iteratorin_iter(cin), eof;

while (in_iter != eof)

4、流迭代器的限制。

(1)不可能從ostream_iterator物件讀入,也不可能寫到istream_iterator物件中。

(2)一旦給ostream_iterator物件賦了乙個值,寫入就提交了。賦值後,沒有辦法再改變這個值。此外,ostream_iterator物件中每個不同的值都只能正好輸出一次。

(3)ostream_iterator沒有->操作。

5、與演算法一起使用流迭代器。

演算法是基於迭代器操作實現的。由於流迭代器支援迭代器操作,因此至少可在一些泛型演算法上使用這類迭代器。

1 #include

2 #include

3 #include

4 #include

5 #include

6 using namespace std;

7 8 int main(void)

9 輸出結果為:

------------------------------分割線------------------------------

C STL迭代器 插入迭代器

include stdafx.h include include include include include 演算法庫對所有在容器上的操作有個承諾 決不修改容器的大小 不插入 不刪除 有了插入迭代器,既使得演算法庫可以通過迭代器對容器插入新的元素,又不違反這一承諾,即保持了設計上的一致性。usi...

C STL 迭代器失效

2 刪除 當進行刪除操作 erase,pop back 後,指向刪除點的迭代器全部失效 指向刪除點後面的元素的迭代器也將全部失效。刪除點之前的迭代器仍有效。二 deque迭代器的失效情況 1 插入 1 在deque容器首部或者尾部插入元素不會使得任何迭代器失效。但是指向存在的元素的引用和指標不會失效...

C STL迭代器失效

迭代器失效就是說,對容器進行了一些操作後,先前的迭代器無法進行解引用操作去訪問容器的元素。迭代器失效可能會造成程式崩潰,如下圖 如果插入元素導致vector達到最大容量,那麼會重新分配記憶體並將老的元素拷貝到新的記憶體中。元素的位址都改變了,顯然迭代器和引用都將失效 如果插入元素沒有引起重新分配記憶...