有指针为何还要STL迭代器
指針和STL迭代器
- 1、迭代器
- 2、迭代器和指針的區別
- 3、迭代器產生原因
1、迭代器
Iterator(迭代器)模式又稱 Cursor(游標)模式,用于提供一種方法順序訪問一個聚合
對象中各個元素, 而又不需暴露該對象的內部表示。或者這樣說可能更容易理解:Iterator 模
式是運用于聚合對象的一種模式,通過運用該模式,使得我們可以在不知道對象內部表示的情況
下,按照一定順序(由 iterator 提供的方法)訪問聚合對象中的各個元素。
由于 Iterator 模式的以上特性:與聚合對象耦合,在一定程度上限制了它的廣泛運用,一
般僅用于底層聚合支持類,如 STL 的 list、vector、stack 等容器類及 ostream_iterator 等擴
展 iterator。
2、迭代器和指針的區別
迭代器不是指針,是類模板,表現的像指針。他只是模擬了指針的一些功能,通過重載了
指針的一些操作符,->、、++、–等。迭代器封裝了指針,是一個“可遍歷 STL( Standard Template
Library)容器內全部或部分元素”的對象, 本質是封裝了原生指針,是指針概念的一種提升
(lift),提供了比指針更高級的行為,相當于一種智能指針,他可以根據不同類型的數據結構
來實現不同的++,–等操作。
迭代器返回的是對象引用而不是對象的值,所以 cout 只能輸出迭代器使用取值后的值而
不能直接輸出其自身。
3、迭代器產生原因
Iterator 類的訪問方式就是把不同集合類的訪問邏輯抽象出來,使得不用暴露集合內部的
結構而達到循環遍歷集合的效果。
總結
以上是生活随笔為你收集整理的有指针为何还要STL迭代器的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 信用卡分期费率是多少
- 下一篇: 平安信用卡逾期利息怎么算