STL概述
STL–string容器
-
STL概述
长久以来,程序员一直希望建立一种可重复利用的东西,C++的面向对象和泛型编程思想,函数以及模板,目的就是复用性的提升,大多情况下,数据结构和算法都未能有一套标准,导致被迫使程序员从事大量重复工作,使用为了建立数据结构和算法的一套标准诞生了STL。
STL(Standard Template Library,标准模板南),STL主要分为:容器(container),算法(algorithm),迭代器(iterator)。容器和算法之间通过迭代器进行无锋连接。STL几乎所有的代码都采用了模板考或者模板函教。
STL大体分为六大组件,分别是:容器。算法。迭代器。仿函故.适配器(配接器)。空间配置器。
(1).容器:各种数据结构,如string,vector, list. deque,set.,map等,用来存放数据。
(2).算法:各种常用的算法,如sort, find, find_if,count,copy. for_ each等
(3).迭代器:扮演了容器与算法之间的胶合剂,迭代器是一个变量,相当于容器和操纵容器的算法之间的中介。
(4).仿函数:行为类似函数,可作为算法的某种策略,其本质是一个类,只不过类里重载了()操作符,使其有了类似函数的功能。
(5).适配器: 一种用来修饰容器或者仿函数或迭代器接口的东西,STL适配器有三种,一种是迭代器适配器,一种是函数适配器,最后一种则是容器适配器。
(6).空间配置器:负责空间的配置与管理,比如new,delete。 -
STL–string容器
string容器是用来存放字符串的,与C语言中的char *p/char p[]存放字符串有什么区别呢?区别就是string本质上是一个类,类中封装了char *p/char p[]用来管理字符串,并且string类里有许多成员函数供对象调用,而char p/char p[]本质上是一个指针。
string容器的成员函数如下:
构造函数:string():创建一个空的字符串 。
string(const char s):使用字符串s初始化。
string(const string& str):使用一 个string对象初始化另一个string对象。
string(int n,char C):使用n个字符c初始化。
string str;//创建一个空的字符串 。
string str1("STL");//使用字符串s初始化。
string str2(str2);//使用一 个string对象初始化另一个string对象。
string str3(5,'a');//使用n个字符c初始化。
成员函数:
(1)赋值操作
string& operator=(const chart s):char*类型字符串赋值给当前的字符串
string& assign(const char *s,int n):把字符串s的前n个字符赋给当前的字符串
string& assign(int n,char c):用n个字符C赋给当前字符串
string str;
string str1("hello");
str="STL";
str.assign("HELLO",4);
str.assign(3,'A');
(2)字符串拼接
string& operator+=(const char *str):将str字符串加到串尾部
string& append(const char *s):把字符串s连接到当前字符串结尾
string& append(const char *s,int n):把字符串s的前n个字符连接到当前字符申结尾
string& append(const string &s,int pos, int n):字符串s中从pos开始的n个字符连接到字符串结尾
string str;
string str1("hello");
str="STL";
str+="hello";
str.append("hello");
str.append("hello",4);
str.append(str1,0,4);
(3)字符串查找与替换
int find(const string& str, int pos):查找str第一次出现位置,从pos开始查找
string& replace(int pos,int n,const string& str):替换从pos开始n个字符为字符串str
str="STL";
str.find("S",0);
str.replace(0,2,"hello");
(4)字符串比较
int compare(const string &str):比较两个字符串是否相等或者大小
str.compare(str1);
(5)字符串存取
char &operator(int n):使用[n]来获取字符串中的值
char &at(int n):使用at成员函数来获取字符串的值
str[0]='X';
str.at(0)='X';
(6)字符串的插入与删除
int insert(int pos,const string& str ):往字符串的第pos位置中插入str字符串,pos为迭代器
int erase(int pos,int n):删除第pos位置的n个字符,pos为迭代器
str.insert(0,"hello");
str.erase(0,2) ;
(7)获取子串
int substr(int pos,int n):获取字符串中第pos位置的n个字符,pos为迭代器
str.substr(0,2);
好了,这就是STL中string容器的具体用法,当然其中还有许多成员函数并没有写出来,若想补充或者对STL有什么问题请在下面评论,谢谢。