目录
一,vector介绍
二,vector使用
构造函数
vector iterator使用
vector空间增长问题
vector增删查改
vector迭代器失效问题
三,vector深度剖析及模拟实现
一,vector介绍
二,vector使用
int main()
{
vector v1; //默认无参构造
vector v2(4, 10); //填充构造
vector v3(v2); //拷贝构造
vector v4(v3.begin(), v3.end()); //迭代器初始化,数据类型要匹配
return 0;
}
int main()
{
vector v(4, 10); //填充构造
for (size_t i = 0; i < v.size(); i++)
{
cout << v[i] << " ";
}
cout << endl;
vector::iterator it = v.begin();
while (it != v.end())
{
cout << *it << " ";
++it;
}
cout << endl;
for (auto i : v)
{
cout << i << " ";
}
return 0;
}
int main()
{
vector v(4, 10);
cout << v.size() << " " << v.capacity() << endl;
cout << endl;
v.reserve(10);
cout << v.size() << " " << v.capacity() << endl;
cout << endl;
v.resize(20);
cout << v.size() << " " << v.capacity() << endl;
cout << endl;
cout << v.empty() << endl;
return 0;
}
int main()
{
vector v(4, 10);
vector v2(2, 3);
v.push_back(1);
v.push_back(2);
v.push_back(3);
v.pop_back();
v.insert(v.begin(), 1);
v.insert(v.begin(), 5, 2);
v.erase(v.begin());
v.erase(v.begin(), v.begin() + 5);
v.swap(v2);
swap(v, v2);
find(v.begin(), v.end(), 2); //算法模块实现的,返回迭代器
sort(v.begin(), v.end());
return 0;
}
可能导致迭代器失效的操作:
注:在使用前,对迭代器重新赋值即可解决迭代器失效的问题;
int main()
{
vector v;
v.push_back(1);
v.push_back(2);
v.push_back(3);
v.push_back(4);
auto pos = find(v.begin(), v.end(), 2);
if (pos != v.end())
{
v.insert(pos, 20);
//或 v.erase(pos);
}
//insert导致增容,pos任指向原释放的位置,迫使失效
//即使没有增容,依然认为迫使失效,因为意义改变了,不在指向原来的值
//但g++没有报错,检查环境不一样
//失效后,不要*pos访问,会出问题;
cout << *pos << endl;
*pos = 10;
return 0;
}
三,vector深度剖析及模拟实现
namespace myvector
{
template
class vector
{
public:
typedef T* iterator;
typedef const T* const_iterator;
iterator begin() { return _start; }
iterator end() { return _finish; }
const_iterator begin()const { return _start; }
const_iterator end()const { return _finish; }
public:
vector()
:_start(nullptr)
,_finish(nullptr)
,_endofstorage(nullptr)
{}
//InputIterator表示不仅限于iterator
template
vector(InputIterator first, InputIterator last)
: _start(nullptr)
, _finish(nullptr)
, _endofstorage(nullptr)
{
while (first != last)
{
push_back(*first);
++first;
}
}
//传统写法1
//vector(const vector& v) //或vector(const vector& v)
//{
// _start = new T[v.capacity()];
// memcpy(_start, v._start, sizeof(T) * v.size());
// _finish = _start + v.size();
// _endofstorage = _start + v.capacity();
//}
//传统写法2(推荐)
//vector(const vector& v)
// :_start(nullptr)
// , _finish(nullptr)
// , _endofstorage(nullptr)
//{
// reserve(v.capacity());
// for (const auto e : v)
// {
// push_back(e);
// }
//}
//现代写法
vector(const vector& v)
:_start(nullptr)
, _finish(nullptr)
, _endofstorage(nullptr)
{
vector tmp(v.begin(), v.end());
swap(tmp);
}
//传统写法
//vector& operator=(const vector& v)
//{
// if (this != &v)
// {
// delete[] _start;
// _start = _finish = _endofstorage = nullptr;
// reserve(v.capacity());
// for (const auto e : v)
// {
// push_back(e);
// }
// }
// return *this;
//}
//现代写法
vector& operator=(vector v)
{
swap(v);
return *this;
}
~vector()
{
delete[] _start;
_start = _finish = _endofstorage = nullptr;
}
void reserve(size_t n)
{
if (n > capacity())
{
size_t sz = size();
T* tmp = new T[n];
memcpy(tmp, _start, sizeof(T) * sz);
_start = tmp;
_finish = _start + sz;
_endofstorage = _start + n;
}
}
void resize(size_t n, const T& val = T())
{
if (n <= size())
{
_finish = _start + n;
}
else
{
if (n > capacity())
reserve(n);
while (_finish < _start + n)
{
*_finish = val;
++_finish;
}
}
}
T& operator[](size_t i)
{
assert(i < size());
return _start[i];
}
const T& operator[](size_t i) const
{
assert(i < size());
return _start[i];
}
void push_back(const T& x)
{
//if (_finish == _endofstorage)
//{
// size_t newcapacity = capacity() ? capacity() * 2 : 4;
// reserve(newcapacity);
//}
//*_finish = x;
//++_finish;
insert(end(), x);
}
void pop_back()
{
//assert(_finish != _start);
//--_finish;
erase(--end());
}
iterator insert(iterator pos, const T& val)
{
assert(pos >= _start && pos <= _finish);
if (_finish == _endofstorage)
{
size_t len = pos - _start;
size_t newcapacity = capacity() ? capacity() * 2 : 4;
reserve(newcapacity);
pos = _start + len;
}
iterator end = _finish - 1;
while (end >= pos)
{
*(end + 1) = *end;
--end;
}
*pos = val;
++_finish;
return pos;
}
iterator erase(iterator pos)
{
assert(pos >= _start && pos < _finish);
iterator it = pos + 1;
while (it != _finish)
{
*(it - 1) = *it;
++it;
}
--_finish;
return pos;
}
void swap(vector& v)
{
std::swap(_start, v._start);
std::swap(_finish, v._finish);
std::swap(_endofstorage, v._endofstorage);
}
size_t size() const
{
return _finish - _start;
}
size_t capacity() const
{
return _endofstorage - _start;
}
private:
iterator _start;
iterator _finish;
iterator _endofstorage;
};
}