const迭代器与const_iterator类型的区别

本文解析了两种迭代器的概念:const迭代器被视为指向对象的常指针;const_iterator迭代器则被视为指向常对象的指针。这两种迭代器在使用中分别体现了指针的常量属性和所指向对象的常量属性。
const  迭代器呢,你把它理解为 指向对象的  常指针,即指针是常量
const_iterator 迭代器呢,你把它理解为 指向 常对象 的指针,即指针指向的对象是常量
前插型迭代器front_insert_iterator是STL中的一种迭代器类型,用于将元素插入容器的头部而不是尾部。它可以适用于所有支持push_front操作的容器,如list和deque等。 使用前提:需要使用一个支持push_front操作的容器,如list或deque。 定义方法:可以通过以下方式定义一个前插型迭代器front_insert_iterator: ``` template <typename Container> class front_insert_iterator { public: // 构造函数,接受一个容器作为参数 explicit front_insert_iterator(Container& x) : container(&x) {} // 重载运算符* front_insert_iterator& operator*() { return *this; } // 重载运算符++ front_insert_iterator& operator++() { return *this; } // 重载运算符++(后缀) front_insert_iterator operator++(int) { return *this; } // 重载运算符= front_insert_iterator& operator=(const typename Container::value_type& value) { container->push_front(value); return *this; } private: Container* container; }; ``` 其中,Container是容器的类型,value_type是容器中存储的元素类型。通过以上定义,就可以使用front_insert_iterator将元素插入容器的头部了。例如,可以通过以下方式将元素插入list的头部: ``` #include <iostream> #include <list> #include <iterator> using namespace std; int main() { list<int> mylist = {1, 2, 3, 4, 5}; front_insert_iterator<list<int>> myfront(mylist); *myfront = 6; ++myfront; *myfront = 7; for (auto i : mylist) { cout << i << " "; } return 0; } ``` 输出结果为:7 6 1 2 3 4 5。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值