STL——string介绍

目录

定义:包含了几种构造函数以及拷贝构造

属性: 最重要的是开辟空间大小的问题(容量的问题)

修改:删、改、查

操作函数:比较,复制,查找子串,交换

运算符重载:

迭代器:

两个算法:


学习过程:定义-属性-修改-操作函数-运算符重载-迭代器-两个算法

#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>());//实现了从大到小
发布了114 篇原创文章 · 获赞 28 · 访问量 4万+

猜你喜欢

转载自blog.csdn.net/ChaoFeiLi/article/details/104260579