当前位置: 首页 > news >正文

网站免费源码大全无需下载青岛网络推广

网站免费源码大全无需下载,青岛网络推广,临泉做网站,合肥平台网站建设快乐的流畅:个人主页 个人专栏:《C语言》《数据结构世界》《进击的C》 远方有一堆篝火,在为久候之人燃烧! 文章目录 引言一、结点二、迭代器2.1 成员变量与默认成员函数2.2 operator*2.3 operator->2.4 operator2.5 operator- …



快乐的流畅:个人主页


个人专栏:《C语言》《数据结构世界》《进击的C++》

远方有一堆篝火,在为久候之人燃烧!

文章目录

  • 引言
  • 一、结点
  • 二、迭代器
    • 2.1 成员变量与默认成员函数
    • 2.2 operator*
    • 2.3 operator->
    • 2.4 operator++
    • 2.5 operator- -
    • 2.6 relational operators
  • 三、list
    • 3.1 成员变量
    • 3.2 迭代器
      • 3.2.1 begin
      • 3.2.2 end
    • 3.3 默认成员函数
      • 3.3.1 constructor
      • 3.3.2 destructor
      • 3.3.3 copy constructor
      • 3.3.4 operator=
    • 3.4 修改
      • 3.4.1 insert
      • 3.4.2 push_front
      • 3.4.3 push_back
      • 3.4.4 erase
      • 3.4.5 pop_front
      • 3.4.6 pop_back
      • 3.4.7 clear
      • 3.4.8 swap
  • 总结

引言

因为list结构的特殊性,所以拆分为结点、迭代器和list本身进行学习。

一、结点

细节:

  1. 使用struct,标明公有属性(这样从外部调用比较方便
  2. list是带头双向循环链表
  3. 提供全缺省的默认构造函数
template<class T>
struct __list_node
{__list_node<T>* _prev;__list_node<T>* _next;T _data;__list_node(const T& x = T()): _prev(nullptr), _next(nullptr), _data(x){}
};

二、迭代器

由于list的每个结点物理空间不连续,导致迭代器不能像之前string、vector那样简单的设计为指针,而是设计为一个类(进行封装),以此完成*、->、++、–等一系列操作。

2.1 成员变量与默认成员函数

细节:

  1. 仍然使用struct,标明公有属性
  2. 成员变量是一个结点的指针
  3. 提供带参构造函数(其余的默认成员函数不用显式定义,浅拷贝即可)
template<class T, class Ref, class Ptr>
struct __list_iterator
{typedef __list_node<T> node;typedef __list_iterator<T, Ref, Ptr> self;node* _node;__list_iterator(node* n): _node(n){}
};

此时的迭代器设计,可以说是list乃至STL的精华,天才般地运用了类的优势。

2.2 operator*

细节:

  • 返回引用,为了区别普通迭代器和const迭代器
Ref operator*()
{return _node->_data;
}

2.3 operator->

细节:

  • 返回指针,为了区别普通迭代器和const迭代器
Ptr operator->()
{return &_node->_data;
}

2.4 operator++

细节:

  1. 为了区分前置和后置,后置参数加上int(无实际意义,以示区分)
  2. 前置传引用返回,后置传值返回
self& operator++()//前置++
{_node = _node->_next;return *this;
}self operator++(int)//后置++
{self tmp(*this);_node = _node->_next;return tmp;
}

2.5 operator- -

细节:同上

self& operator--()//前置--
{_node = _node->_prev;return *this;
}self operator--(int)//后置--
{self tmp(*this);_node = _node->_prev;return tmp;
}

2.6 relational operators

bool operator!=(const self& s)
{return _node != s._node;
}bool operator==(const self& s)
{return _node == s._node;
}

三、list

3.1 成员变量

list类包含了

  • _head(指向哨兵位)
template<class T>
class list
{
public:typedef __list_node<T> node;
private:node* _head;
};

3.2 迭代器

typedef __list_iterator<T, T&, T*> iterator;
typedef __list_iterator<T, const T&, const T*> const_iterator;

3.2.1 begin

细节:

  1. begin()在_head->next
  2. 使用匿名对象
iterator begin()
{return iterator(_head->_next);
}const_iterator begin() const
{return const_iterator(_head->_next);
}

3.2.2 end

细节:

  1. end()在_head
  2. 使用匿名对象
iterator end()
{return iterator(_head);
}const_iterator end() const
{return const_iterator(_head);
}

3.3 默认成员函数

3.3.1 constructor

空初始化:创建哨兵位

void empty_init()
{_head = new node;_head->_prev = _head;_head->_next = _head;
}

无参构造

list()
{empty_init();
}

迭代器区间构造

细节:使用类模板,可以传任意类型的迭代器

template <class InputIterator>
list(InputIterator first, InputIterator last)
{empty_init();while (first != last){push_back(*first);++first;}
}

3.3.2 destructor

~list()
{clear();delete _head;_head = nullptr;
}

3.3.3 copy constructor

现代写法

细节:

  1. 迭代器区间构造,构造出临时对象
  2. 再使用list中的swap,交换*this和tmp的值,完成拷贝构造
list(const list<T>& lt)
{empty_init();list<T> tmp(lt.begin(), lt.end());swap(tmp);
}

3.3.4 operator=

现代写法

细节:

  1. 传参变成传值,这样就会拷贝构造出一个临时对象
  2. 再使用list中的swap,交换*this和tmp的值,完成赋值重载
list<T>& operator=(list<T> lt)
{swap(lt);return *this;
}

3.4 修改

3.4.1 insert

指定位置插入

细节:

  1. 在pos之前插入
  2. 迭代器不会失效
void insert(iterator pos, const T& x)
{node* cur = pos._node;node* prev = cur->_prev;node* new_node = new node(x);prev->_next = new_node;new_node->_prev = prev;cur->_prev = new_node;new_node->_next = cur;
}

3.4.2 push_front

头插

void push_front(const T& x)
{insert(begin(), x);
}

3.4.3 push_back

尾插

void push_back(const T& x)
{insert(end(), x);
}

3.4.4 erase

指定位置删除

细节:

  1. assert断言,防止删除哨兵位
  2. 返回删除节点的下一位,防止迭代器失效
iterator erase(iterator pos)
{assert(pos != end());node* cur = pos._node;node* prev = cur->_prev;node* next = cur->_next;prev->_next = next;next->_prev = prev;delete cur;return iterator(next);
}

3.4.5 pop_front

void pop_front()
{erase(begin());
}

3.4.6 pop_back

void pop_back()
{erase(--end());
}

3.4.7 clear

清除所有结点(除哨兵位以外)

void clear()
{iterator it = begin();while (it != end()){erase(it++);}
}

3.4.8 swap

交换两个list类的值

细节:使用std库中的swap函数,交换各个成员变量的值

void swap(list<T>& lt)
{std::swap(_head, lt._head);
}

总结

学习完list类,对于STL中的精华——迭代器设计,有了更深一步的了解。同时,了解多参数模板的用途和方法,极大提高代码复用程度。


真诚点赞,手有余香

http://www.yayakq.cn/news/749780/

相关文章:

  • 济南浩特元辰建设工程有限公司网站潞城网络营销怎么做
  • 企业网站的管理系统彩页模板
  • 上海 微信网站 建站wnmp搭建wordpress
  • 做网站卖什么东西好百度指数是免费的吗
  • 网站建设app端建网站权威公司
  • seo人员要先对网站进行诊断中信建设有限责任公司山东分公司
  • 网站建设微信软文长沙网页制作设计
  • 南阳专业做网站公司微信管理系统登录入口
  • 黑龙江省建设安全网站wordpress单题问卷
  • 燕郊医疗网站建设亳州有做网站的吗
  • 南宁制作网站公司wordpress中文官网地址
  • 广州网站优化微信app下载安装官方版
  • 电子商务网站建设与管理实务国外搜索引擎排名
  • 网站设计背景图片怎么做的枣庄seo外包
  • 山东网站建设开发维护雍鑫建设集团官方网站
  • 淘宝网站制作培训彩票源码论坛
  • 建设通网站原理百度统计数据
  • 文学网站怎样建设相亲网站的女人 做直播的
  • 芜湖营销型网站建设建设网站的个人心得体会
  • 如何做个网站做cpa本地做网站教程
  • 怎么用新浪云做网站坪山住房及建设局网站
  • 灵犀科技网站开发佼佼者深圳百度推广seo公司
  • 跨境电商网站 建设要求网站建设 技术 哪些方面
  • 网站做网站词怎么推广网站用户注册增加办法
  • 网站登录不上做网站的自我介绍
  • 网站代码隐蔽代码网站开发和app开发的区别
  • 搭建cms网站百度怎么添加店铺地址
  • 巴州网站建设库尔勒网站建设钟爱网络百度爱采购推广平台
  • 做网站年入千万如何建立一个网站分享教程
  • 51做网站建设企业官网2019为网站网站做代理被判缓刑