您的位置:首页 > 编程语言 > C语言/C++

C++ STL Vector 学习报告

2016-04-20 21:47 288 查看
Vector
1.头文件
#include <vector>
2.函数列表
构造函数
vector();
构造一个空的vector

vector(size_type num, const TYPE &val);
构造一个初始放入num个值为val的元素的Vector

vector(const vector &from);
构造一个与vector from相同的vector

vector(input_iterator start, input_iterator end);
迭代器(start)和迭代器(end)-构造一个初始值为[start,end)区间元素的Vector
assign函数
void assign( input_iterator start, input_iterator end );
将区间[start, end)的元素赋到当前vector

void assign( size_type num, const TYPE &val );

赋num个值为val的元素到vector中.这个函数将会清除掉为vector赋值以前的内容.
at函数
TYPE at(size_type loc);
返回当前Vector指定位置loc的元素的引用. at() 函数 比 [] 运算符更加安全, 因为
它不会让你去访问到Vector内越界的元素,如:
vector<int> v( 5, 1 );

for( int i = 0; i < 10; i++ )

{cout << "Element " << i << " is " << v.at(i) << endl;}

取代试图访问内存里非法值的作法,at() 函数能够辨别出访问是否越界并在越界的时候抛出
一个异常out_of_range.
back 函数

TYPE back();

返回当前vector最末一个元素的引用.如:

vector<int> v;

for( int i = 0; i < 5; i++ )
{ v.push_back(i); }

cout<<"The firstelement is "<<v.front()<<"and the last element is"<<v.back()<<endl;

结果:

The first element is 0 and the last element is 4

begin 函数

iterator begin();

begin()函数返回一个指向当前vector起始元素的迭代器.如:

vector<int> v1( 5, 789 );

vector<int>::iterator it;

for( it = v1.begin(); it != v1.end(); it++ )

{cout << *it << endl; }

capacity 函数

size_type capacity();

返回当前vector在重新进行内存分配以前所能容纳的元素数量.

clear 函数

void clear();

删除当前vector中的所有元素.

empty 函数

bool empty();

如果当前vector没有容纳任何元素,则empty()函数返回true,否则返回false.例如,以下代码
清空一个vector,并按照逆序显示所有的元素:

vector<int> v;

for( int i = 0; i < 5; i++ ) {

v.push_back(i);

}

while( !v.empty() ) {

cout << v.back() << endl;

v.pop_back();

}

end 函数

iterator end();

返回一个指向当前vector末尾元素的下一位置的迭代器.注意,如果你要访问末尾元素,需要先
将此迭代器自减1.

erase 函数 (返回值是指向删除的最后一个元素的下一位置的迭代器

iterator erase(iterator loc);
删除指定位置loc的元素

iterator erase( iterator start, iterator end );
删除区间[start, end)的所有元素

如:

vector<char> alphaVector;// 创建一个vector,置入字母表的前十个字符
for( int i =0; i < 10; i++ )
alphaVector.push_back( i + 65 );
int size = alphaVector.size();
vector<char>::iterator startIterator;
vector<char>::iterator tempIterator;
for( int i=0; i < size; i++ )

{

tartIterator = alphaVector.begin();

alphaVector.erase(startIterator);
// Display the vector
for(tempIterator=alphaVector.begin();tempIterator!=alphaVector.end();tempIterator++)

cout << *tempIterator << endl;

}

这段代码将会显示如下输出:
BCDEFGHIJ

CDEFGHIJ

DEFGHIJ

EFGHIJ

FGHIJ

GHIJ

HIJ

IJ

J
front 函数

TYPE front();

返回当前vector起始元素的引用

get_allocator 函数

allocator_type get_allocator();

返回当前vector的内存分配器.
STL中一般不会调用new或者alloc来分配内存,而且通过一个allocator对象的相关方法来分配.

如:
vector<int>v3(3,1,v2.get_allocator());
//把V2的内存分配器作为一个参数参与构造V3。这样,它们两个用一个内存分配器了。

insert 函数

iterator insert(iterator loc, const TYPE &val);
在指定位置loc前插入值为val的元素,返回指向这个元素的迭代器,
void insert(iterator loc,size_type num, const TYPE &val);
在指定位置loc前插入num个值为val的元素

void insert(iteratorloc,input_iterator start,input_iterator end);
在指定位置loc前插入区间[start, end)的所有元素 .

如:

//创建一个vector,置入字母表的前十个字符
vector<char> alphaVector;
for( int i=0; i < 10; i++ )
alphaVector.push_back( i + 65 );
//插入四个C到vector中
vector<char>::iterator theIterator = alphaVector.begin();
alphaVector.insert(theIterator,4,'C');
//显示vector的内容
for(theIterator=alphaVector.begin();theIterator!=alphaVector.end();theIterator++)
cout<<*theIterator;

这段代码将显示:

CCCCABCDEFGHIJ

max_size 函数

size_type max_size();

返回当前vector所能容纳元素数量的最大值(译注:包括可重新分配内存).

pop_back

void pop_back();

pop_back()函数删除当前vector最末的一个元素,例如:
vector<char> alphaVector;
for( int i=0; i < 10; i++ )
alphaVector.push_back( i + 65 );
int size = alphaVector.size();
vector<char>::iterator theIterator;
for( int i=0; i < size; i++ )
{
alphaVector.pop_back();
for(theIterator=alphaVector.begin();theIterator!=alphaVector.end();theIterator++)
cout << *theIterator;
cout << endl;
}这段代码将显示以下输出:
ABCDEFGHI

ABCDEFGH

ABCDEFG

ABCDEF

ABCDE

ABCD

ABC

AB

A

push_back 函数

void push_back( const TYPE &val );

添加值为val的元素到当前vector末尾

rbegin 函数

reverse_iterator rbegin();

返回指向当前vector末尾的逆迭代器.
(译注:实际指向末尾的下一位置,而其内容为末尾元素的值)如:

vector<int>v1;

for(int i=1;i<=5;i++)

{ v1.push_back(i);}

vector<int>::reverse_iterator pos;

pos=v1.rbegin();

cout<<*pos<<" ";

pos++;

cout<<*pos<<endl;

输出结果为: 5 4

rend 函数

reverse_iterator rend();

返回指向当前vector起始位置的逆迭代器.如:

vector<int>v1;

for(int i=1;i<=5;i++)

{ v1.push_back(i); }

vector<int>::reverse_iterator pos;

pos=v1.rend();

pos--;

cout<<*pos<<" ";

pos--;

cout<<*pos<<endl;

输出结果为:1 2

reserve 函数

void reserve( size_type size );

为当前vector预留至少共容纳size个元素的空间.(译注:实际空间可能大于size)

resize 函数

void resize( size_type size, TYPE val );

改变当前vector的大小为size,且对新创建的元素赋值val

size 函数

size_type size();

返回当前vector所容纳元素的数目

swap 函数

void swap( vector &from );

交换当前vector与vector from的元素

示例:

vector<int>v1,v2;
for(int i=1; i<=3; i++)
{
v1.push_back(i);
v2.push_back(i);
}
v2.push_back(4);
v2.push_back(5);
v1.swap(v2);
for(int j=0; j<v1.size(); j++)
{
cout<<v1[j]<<" ";
}
cout<<endl;
for(int k=0; k<v2.size(); k++)
{
cout<<v2[k]<<" ";
}
cout<<endl;
输出结果为:

1 2 3 4 5

1 2 3
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: