C++ STL Vector

栏目: 编程工具 · 发布时间: 6年前

内容简介:C++ STL Vector 是经典的连续存储空间的数据。它有两个模板参数:这三个指针指向的是当前 vector 存储的空间和位置信息,这些在迭代器部分提供非常方便的实现。例如

简介

C++ STL Vector 是经典的连续存储空间的数据。它有两个模板参数:

_Alloc

vector 的实现比较简单,其实也不简单。它考虑了很多的性能优化,例如对于简单类型复制构造使用更高效的 uninitialized_copy/fill ; 扩张内存时,其内存扩张策略;兼容不同的 allocator (这部分工作感觉很多容器都会考虑)

实现细节

_M_start
_M_finish
_M_end_of_storage

这三个指针指向的是当前 vector 存储的空间和位置信息,这些在迭代器部分提供非常方便的实现。例如 begin 可以返回 _M_startsize() 实现为 end() - begin() ,本质还是指针间的运算。

增加元素的操作

  • push_back
  • insert
    • insert(iterator __pos)
      • 不知道为什么这个函数没有调用下面的函数来实现
    • insert(iterator __pos, const _Tp& __x)
    • insert(iterator __pos, InputIterator __first, InputIterator __last)
    • insert(iterator __pos, size_type __n, const _Tp& __x)

push_back 操作在 _M_end_of_storage > _M_finish 时,只需要做下移动即可。其它情况需要做内存的扩张。

vector<_Tp, _Alloc>::_M_insert_aux(iterator __position, const _Tp& __x) {
    /* _M_finish != _M_end_of_storage */
    /* 增加 _M_finish, 然后反向复制,最后在 __position 位置插入元素*/

    /* new_size = old_size == 0 ? 1 : 2 * old_size */
    /* 复制 _M_start->__position */
    /* 复制 __position->_M_finish */
    /* 赋值 __position 位置的值 */
}

疑惑点:

  • 为什么要调用一下 construct ?
    • 那部分 _M_end_of_storage 标记的只是内存空间,并没有初始化,所以必须先 construct ,然后再复制
    • else 分支中调用了: uninitialized_copy ,函数内部会根据情况去调用复制构造函数
  • 复制一份 __x : 放置变量会被覆盖吗?
    • 放置传入的引用是在 copy_backward 的方位之内

删除元素的操作

  • pop_back
  • erase
    erase(iterator __position)
    erase(iterator __first, iterator __last)
    

pop_back 的实现比较简单,标记下 _M_finish ,然后 destroy 掉之前位置的元素即可。 erase 的实现 是类似的,只不过从末位换到一个任意位置,或者区间。注意 erase 返回的是删除元素的下一个位置。该 返回值主要用于遍历删除。

/* delete all elements in an array of int */

void delete_ele(vector<int> array, int target) {
    auto beg = array.begin();
    auto end = array.end();
    while (beg != end) {
        if (*beg == target) {
            beg = erase(beg);
        } else {
            ++beg;
        }
    }
}

其它操作

  • assign
    • assign 会替换掉整个 vector 的内容
    • 有直接插入值和插入一个区间两种实现
  • swap
    • swap 的实现其实比较简单,就是交换之前存储的三个状态值即可。
  • comparison
    • 比较的实现主要是实现 ==< 。前者使用 equal 实现,后者是 lexicographical_compare

本文完

C++ STL Vector

This work is licensed under a CC A-S 4.0 International License

.


以上所述就是小编给大家介绍的《C++ STL Vector》,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对 码农网 的支持!

查看所有标签

猜你喜欢:

本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们

Head First Java(第二版·中文版)

Head First Java(第二版·中文版)

Kathy Sierra,Bert Bates 著、杨尊一 编译 张然等 改编 / 杨尊一 / 中国电力出版社 / 2007-2 / 79.00元

《Head First Java》是本完整的面向对象(object-oriented,OO)程序设计和Java的学习指导。此书是根据学习理论所设计的,让你可以从学习程序语言的基础开始一直到包括线程、网络与分布式程序等项目。最重要的,你会学会如何像个面向对象开发者一样去思考。 而且不只是读死书,你还会玩游戏、拼图、解谜题以及以意想不到的方式与Java交互。在这些活动中,你会写出一堆真正的Jav......一起来看看 《Head First Java(第二版·中文版)》 这本书的介绍吧!

RGB转16进制工具
RGB转16进制工具

RGB HEX 互转工具

Markdown 在线编辑器
Markdown 在线编辑器

Markdown 在线编辑器

UNIX 时间戳转换
UNIX 时间戳转换

UNIX 时间戳转换