所有的標準容器都定義了相應的迭代器類型。迭代器對所有的容器都使用,現代C++程序更傾向于使用迭代器而不是下標操作訪問容器元素。
1、iterator,const_iterator 作用:遍歷容器內的元素,并訪問這些元素的值。iterator可以改變元素值,但const_iterator不可改。跟C的指針有點像
(容器均可以++iter, 而vector還可以iter-n,iter+n,n為一整型,iter1-iter2結果是difference_type類型,表兩元素的距離)
2、const_iterator對象可以用于const vecter 或非const vector,它自身的值可以改(可以指向其他元素),但不能改寫其指向的元素值。
3、const iterator與const_iterator是不一樣的:聲明一個const iterator時,必須初始化它。一旦被初始化后,就不能改變它的值,它一旦被初始化后,只能用它來改它指的元素,不能使它指向其他元素。
(因此const iterator幾乎沒什么用途)
例 vector<int> nums(10); // nums is nonconst const vector<int>::iterator cit = nums.begin(); *cit = 1; // ok: cit can change its underlying element ++cit; // error: can't change the value of cit
例:讀入一段文本到 vector 對象,每個單詞存儲為 vector 中的一個元素。把 vector 對象中每個單詞轉化為小寫字母。輸出 vector 對象中轉化后的元素,每八個單詞為一行輸出
--摘自C++primer 3.14 //自己寫的一個代碼,于VS2008測試通過,因是VC6.0對標準C++支持不好,若要測試,需要更改預處理. //用下標操作 #include <iostream> #include <string> #include <vector> using std::vector; using std::string; using std::cout; using std::cin; using std::endl; int main() { vector<string> svec; string word; while (cin>>word) svec.push_back(word); for (vector<string>::size_type ix=0;ix!=svec.size();++ix) { for (string::size_type index=0;index!=svec[ix].size();++index) //注: svec[ix].size()返回類型為 string::size_type { svec[ix][index]=tolower(svec[ix][index]); } } for (vector<string>::size_type ix=0;ix!=svec.size();++ix) { cout<<svec[ix]<<' '; if ((ix+1)%8==0) { cout<<endl; } } getchar(); return 0;
} //用iterator改進... int main() { vector<string> svec; string word; while (cin>>word) svec.push_back(word);
for (vector<string>::iterator iter=svec.begin();iter!=svec.end();++iter) //因要改寫,故應用iterator for (string::iterator iter2=(*iter).begin();iter2!=(*iter).end();++iter2) *iter2=tolower(*iter2); //上面兩行代碼亦改為: for (string::size_type index=0;index!=(*iter).size();++index) //但不建議 (*iter)[index]=tolower((*iter)[index]); int ix=0; for (vector<string>::const_iterator iter=svec.begin();iter!=svec.end();++iter,++ix) //因只是讀取,故可用const_iterator { cout<<*iter<<' '; if ((ix+1)%8==0) { cout<<endl; } } getchar(); return 0; }
|