目录
学习过程:定义-属性-修改-操作函数-运算符重载-迭代器-两个算法
#include<string>
using namespace std;
//一起使用,否则出错
定义:包含了几种构造函数以及拷贝构造
属性: 最重要的是开辟空间大小的问题(容量的问题)
开辟空间大小和编译器有关:
VS2005:首先开辟15个,然后依次增加16个空间大小
VC6.0:首先开辟31个,然后依次增加32个空间大小
capacity()函数,返回开辟空间大小
reverse():修改容量大小,只能扩容,不能变小
修改:删、改、查
删:
改:包含了三部分->修改指定元素,插入,赋值
修改指定元素:
插入:中间插入,尾部插入
赋值:重载“=”运算符,“>>”运算符和assign()函数
查:运算符重载<<
操作函数:比较,复制,查找子串,交换
比较:
复制:
查找子串:
交换:
运算符重载:
迭代器:
就相当于一个指向string对象元素的指针,本质上相当于 一个char* 的指针,可以使用迭代器完成遍历,赋值等操作
string重新申请更大的空间的时候,迭代器会失效(执行append和insert时,如果超过了原先的存储空间,系统会重新开辟一段内存空间,而原先的指向首地址的函数(begin)之后,迭代器会失效,需要重新执行ite = str.begin())
string::iterator ite;
for (ite = str.begin(),int i = 0;ite != str.end(); ite++,i++)
{
cout << *ite;//遍历
cout << ite[i];//遍历
*ite = ‘a’;//赋值
ite[i] = ‘a’;//赋值
}
迭代器部分函数:
两个算法:
遍历函数:
头函数:#include"algorithm"
Function for_each(InputIterator _First, InputIterator _Last, Function _Func );
agr3是一个函数,其中函数类型和类对象里面元素类型相同,是(char,int等)
void fun(char s){
cout<<s;
}
void Foreach(){
string str("sfas;fkjs");
for_each(str.begin(),str.end(),fun);
cout<<endl;
}
排序函数:
头文件:#include"functional"
template<class RandomAccessIterator, class Pr>
void sort( RandomAccessIterator _First, RandomAccessIterator _Last, BinaryPredicate _Comp);
sort(str.begin(),str.end());//默认从小到大
sort(str.begin(),str.end(),greater<char>());//实现了从大到小