STL中vector的底层实现机制及常用操作

本文详细探讨了STL中vector的底层实现机制,包括迭代器、内存管理和构造析构过程。重点讲解了vector的插入、删除元素操作,如push_back()、pop_back()以及insert()等,强调了空间重新配置可能导致迭代器失效。同时,介绍了resize()、assign()等其他常用操作,以及reserve()函数在预留内存方面的作用。
摘要由CSDN通过智能技术生成

本文基于SGI STL vector源码分析其底层实现,只关注核心实现,不考虑空间配置器allocator。

一、vector概述

vector的数据安排以及操作方式,与array非常相似。两者的唯一区别在于空间的运用的灵活性。array是静态空间,一旦配置了就不能改变,要换个大(或小)一点的房子,可以,一切琐细得由客户端自己来:首先配置一块新空间,然后将元素从旧址一一搬往新址,再把原来的空间释还给系统。而vector是动态空间,随着元素的加入,它的内部机制会自行扩充空间以容纳新元素。因此,vector的运用对于内存的合理利用与运用的灵活性有很大的帮助,因此不必因为担心空间不足而一开始就要一个大块头array了。

二、vector的迭代器

vector维护的是一个连续线性空间,所以不论其元素类型是什么,普通指针都可以作为vector的迭代器而满足所有必要条件,因为vector迭代器所需要的操作行为,如operator*,operator->,operator++,operator–,operator+,operator-,operator+=,operator-=,普通指针天生就具备。vector支持随机存取。

三、vector的定义

vector所采用的数据结构非常简单:线性连续空间。它以两个迭代器start和finish分别指向配置得到的连续空间中目前已被使用的范围,并以迭代器end_of_storage指向整块连续空间的尾端。

template <class T, class Alloc = alloc>
class vector{
   
public...
protected:
	iterator start;            //表示目前使用空间的头部
	iterator finish;           //表示目前使用空间的尾部
	iterator end_of_storage;   //表示目前可用空间的尾部
private...
};

两个关键大小:
大小:size() = finish - start;
容量:capacity() = end_of_storage - start;
如下图所示,size()表示vector中已有元素的个数,capacity()表示vector最多可存储的元素的个数。
在这里插入图片描述
为了降低二次分配时的成本,vector实际配置的大小可能比客户需求的更大一些,以备将来扩充,这就是容量的概念。即capacity>=size,当等于时,容器此时已满,若再要加入新的元素时,就要重新进行内存分配,整个vector的数据都要移动到新内存。二次分配成本较高,在实际操作时,应尽量预留一定空间,避免二次分配。

四、vector构造与内存管理

1、构造
vector的构造函数主要有以下几种:

template <class T, class Alloc = alloc>
vector():start(0), finish(0), end_of_storage(0){
   }
vector(size_type n, const T& value){
   
	fill_initializa(n, value);
}
vector(int n, const T& value){
   
	fill_initializa(n, value);
}
vector(long n, const T& value){
   
	fill_initializa(n, value);
}
explicit vector(size_type n){
   
	fill_initializa(n, T());
}

由上述构造函数知,基本上所有构造函数都是基于fill_initialize()实现的。

//填充并予以初始化
void fill_initialize(size_type n, const T& value){
   
	start = allocate_and_fill(n, value);
	finish = start + n;
	end_of_storage = finish;
}
//配置而后填充
iterator allocate_and_fill(size_type n, const T& x){
   
	iterator result = data_allocator::
### 回答1: C++ STL(Standard Template Library)是一种功能强大的库,提供了一套丰富的数据结构和算法实现。在余文溪的《C++ STL数据结构与算法实现》这本PDF书,详细介绍了STL的各种数据结构和算法实现。 首先,STL提供了几种基本的数据结构,例如vector(动态数组)、list(双向链表)、deque(双端队列)、set(集合)、map(映射)等。这些数据结构在STL都有相应的实现操作函数,能够方便地进行插入、删除、查找等操作。 此外,STL还提供了一些算法,包括排序、查找、遍历等等。这些算法可以应用于STL的各种数据结构上,提供了一种高效且易用的方式来处理数据。例如,STL提供了排序算法sort,可以对vector、list等容器进行排序操作;还有查找算法find,可以在set、map等容器进行查找操作。 在《C++ STL数据结构与算法实现,余文溪详细阐述了STL实现原理和内部细节,帮助读者深入理解STL的工作原理。通过学习这本书,读者可以了解到STL的设计思想、使用方法和性能特点,从而能够更好地应用STL解决问题。 总而言之,STL提供了一套强大的数据结构和算法实现,通过余文溪的《C++ STL数据结构与算法实现》这本PDF书,读者可以深入了解STL的使用方法和内部原理,提升编程能力。 ### 回答2: C++ STL(Standard Template Library,标准模板库)是C++标准库的一部分,为我们提供了丰富的数据结构和算法实现。余文溪编写的《C++ STL 数据结构域算法实现》PDF是一本介绍STL的经典教材。 STL包含了很多常用的数据结构,例如向量(vector)、链表(list)、集合(set)和映射(map)等。这些数据结构都已经被封装好,通过STL可以方便地进行插入、删除、查找等操作。同时,STL还提供了强大的算法库,例如排序、查找、拷贝和逆序等。使用STL的数据结构和算法,可以极大地提高我们的编程效率。 《C++ STL 数据结构域算法实现》是一本很好的学习STL的教材。其,余文溪详细地介绍了STL的各种数据结构和算法,通过代码示例和讲解,深入浅出地帮助读者理解STL的使用方法。这本教材适合初学者和有一定基础的读者阅读,对于了解STL的基本概念和使用方法非常有帮助。 在读完《C++ STL 数据结构域算法实现》后,读者将能够熟练使用STL提供的数据结构和算法,加快自己的编程效率。同时,通过掌握STL的使用,读者也能更好地理解C++标准库的设计思想和使用方法,提升自己的编程水平。 总之,《C++ STL 数据结构域算法实现》是值得一读的一本STL教材,能够帮助我们更好地学习和应用STL,提高我们的编程效率和水平。 ### 回答3: STL(Standard Template Library)是C++的标准库之一,提供了丰富的数据结构和算法实现。而余文溪编写的《C++ STL数据结构与算法实现》这本PDF书籍主要介绍了STL的使用方法和内部实现原理。 该书首先介绍了STL的基本概念和使用方法,包括迭代器、容器、算法等方面的内容。通过对各种容器(如vector、list、set、map等)和算法(如排序、查找、合并等)的讲解,读者可以了解到STL的强大功能和高效性。 此外,余文溪在书也深入探讨了STL的内部实现原理。他通过剖析STL的源代码,详细解释了其的数据结构和算法实现细节。这对于希望深入理解STL底层机制的读者来说,是非常有价值的。 《C++ STL数据结构与算法实现》这本书的另一个特点是提供了大量的示例代码和实战练习。通过实际编写代码和完成练习,读者可以巩固所学知识,并提升自己的编程能力。 总之,余文溪的这本PDF书籍对于想要掌握STL的使用方法和底层实现原理的C++程序员来说,是一本非常实用的工具书。无论是初学者还是有一定经验的开发者,都可以从获得很多有价值的知识和技能。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值