自己实现iterator迭代器

简介: 自己实现iterator迭代器
#include <iterator>
#include <iostream>
struct List_node_base {
  List_node_base* M_next;
  List_node_base* M_prev;
};
template <class T>
struct List_node : public List_node_base {
  T M_data;
};
struct List_iterator_base {
  typedef size_t size_type;
  typedef ptrdiff_t difference_type;              // typedef int ptrdiff_t;
  typedef std::bidirectional_iterator_tag iterator_category;
  List_node_base* M_node;
  List_iterator_base(List_node_base* x) : M_node(x) {}
  List_iterator_base() {}
  void M_incr() { M_node == M_node->M_next; }
  void M_decr() { M_node == M_node->M_prev; }
  bool operator==(const List_iterator_base& x) const {
    return M_node == x.M_node;
  }
  bool operator!=(const List_iterator_base& x) const {
    return M_node != x.M_node;
  }
};
template<class T, class Ref, class Ptr>
struct List_iterator : public List_iterator_base {
  typedef List_iterator<T, T&, T*> iterator;
  typedef List_iterator<T, const T&, const T*> const_iterator;
  typedef List_iterator<T, Ref, Ptr> Self;
  typedef T value_type;
  typedef Ptr pointer;
  typedef Ref reference;
  typedef List_node<T> Node;
  List_iterator(Node* x) : List_iterator_base(x) {}
  List_iterator() {}
  List_iterator(const iterator& x) : List_iterator_base(x.M_node) {}
  reference operator*() const { return ((Node*)M_node)->M_data; }
  pointer operator->() const { return &(operator*()); }
  Self& operator++() {
    this->M->incr();
    return *this;
  }
  Self operator++(int) {
    Self tmp = *this;
    this->M_incr();
    return tmp;
  }
  Self& operator--() {
    this->M_decr();
    return *this;
  }
  Self operator--(int) {
    Self tmp = *this;
    this->M_Decr();
    return tmp;
  }
};
template<class T, class Ref, class Ptr>
List_iterator<T, Ref, Ptr> insert(List_iterator<T, Ref, Ptr> position, const T& x) {
  List_node<T>* tmp = M_create_node(x);
  tmp->M_next = position.M_node;
  tmp->M_prev = position.M_node->M_prev;
  position.M_node->M_prev->M_next = tmp;
  position.M_node->M_prev = tmp;
  return tmp;
}
template<class T, class Ref, class Ptr>
List_iterator<T, Ref, Ptr> insert(List_iterator<T, Ref, Ptr> position) {
  return insert(position, T());
}
template<class T, class Ref, class Ptr>
void push_front(const T& x) {
  insert(begin(), x);
}
template<class T, class Ref, class Ptr>
void push_front() {
  insert(begin());
}
template<class T, class Ref, class Ptr>
void push_back(const T& x) {
  insert(end(), x);
}
template<class T, class Ref, class Ptr>
void push_back() {
  insert(end());
}
template<class T, class Ref, class Ptr>
List_iterator<T, Ref, Ptr> erase(List_iterator<T, Ref, Ptr> position) {
  List_node_base* next_node = position.M_node->M_next;
  List_node_base* prev_node = position.M_node->M_prev;
  List_node* n = (List_node*)position.M_node;
  prev_node->M_next = next_node;
  next_node->M_prev = prev_node;
  Destory(&n->M_data);
  M_put_node(n);
  return iterator((List_node*)next_node);
}
int main()
{
  getchar();
  return 0;
}
相关文章
|
6月前
Iterator与ListIterator迭代器
Iterator与ListIterator迭代器
|
5月前
|
C++ 容器
迭代器 iterator
迭代器 iterator
每日一道面试题之迭代器 Iterator 是什么?
每日一道面试题之迭代器 Iterator 是什么?
|
6月前
list转迭代器Iterator
list转迭代器Iterator
|
6月前
|
开发者
迭代器(Iterator)遍历的两种方法(for和while)
迭代器(Iterator)遍历的两种方法(for和while)
|
6月前
|
算法 C++ 容器
c++迭代器介绍
C++中的迭代器是一种抽象的数据访问对象,它允许对容器中的元素进行遍历,而不必暴露底层数据结构的细节。迭代器提供了一种通用的方法来访问容器中的元素,无论容器的类型是什么。C++标准库中的许多容器(如vector、list、map等)都支持迭代器。
78 0
|
设计模式 Java Python
迭代器(Iterator)
迭代器(Iterator)是一种设计模式,用于遍历聚合对象的一种方法。迭代器提供了一种方法来访问聚合对象中的元素,而不需要暴露该对象的内部表示。迭代器模式在 Java 和 Python 等编程语言中广泛使用,可以用于处理列表、元组、集合等数据结构。
56 1
|
6月前
|
Java
Java集合框架:什么是迭代器(Iterator)?
Java集合框架:什么是迭代器(Iterator)?
60 0
|
JavaScript 前端开发 Java
彻底理解 for of 和 Iterator
本文主要来说下ES6的Iterator,目的在于理解它的概念、作用、以及现有的应用,最后学以致用。 Iterator可以说是ES6内相当重大的一个特性,也是很多其他特性运行的基石。 为什么Iterator地位如此之高呢?
121 1
彻底理解 for of 和 Iterator
|
设计模式 开发框架 .NET
C#——迭代器
C#——迭代器
83 0
C#——迭代器