STL中的string是一种特殊类型的容器,除了可以作为字符类型的容器外,更多的是作为一种数据类型----字符串,可以像int,double之类的基本数据类型那样定义string类型的数据,并进行各种运算。此外,string具有字符串的查找,替换,取子串,插入子串等处理能力。
1.string对象的定义和初始化
string c; //定义字符串c,不含任何字符。
string c1("this is a string"); //定义字符串c1,并用指定字符串初始化其内容
string c2=c1; //定义自付出c2,并用c1初始化它
string s[10]; //定义字符串数组,能够保存10个字符串,相当于char[ ][ ];
string s(5,'c'); //定义s,用5个‘c’,即“ccccc”初始化;
2.string类型的赋值
string类型的赋值操作与int等基本类型的赋值操作相同,不必用strcpy()函数
例如:
string s1,s2,s3[3]; //定义string对象及数组
string name[3]=("tom","jerrry","duck"); //string对象数组定义与初始化
s1="this is a string"; //string赋值
s2=s1;
s3[0]=s1; //string数组元素访问
s3[1]="string arr";
3.string类型的连接
用“+”和“+=”可以对;两个string类型对象进行连接运算。例如:
string s1("I am boy"),s3;
string s2="i am come from china!";
s3=s1+","+s2; //s3:I am boy,i come from china!
s1+=","+s2; //s1:I am boy,i come from china!
4.string的常用函数如下:
假设s1,s2的定义如下:
string s1="ABCDEFH";
string s2="0123456123";
string s;
string成员函数如下:
substr(n1,n) //取子串函数,从当前字符串的n1下标开始,取出n个字符。如“s=s1.substr(2,3)”的结 //果为:s="CDE"
swap(s) //交换字符串。如“s1.swap(s2)”的结果为:s1="0123456123" ,s2="ABCDEFH"
size()/length() //计算字符串中当前存放的字符个数。如"s1.length()"的结果为7
capacity() //计算字符串的容量(可容纳的字符个数)。"s1.capacity()"的结果为31
max_size() //计算string类型数据的最大容量。
find(s) //在当前字符串中查找子串s,如果找到就返回s在当前串中的起始位置.如果没有找到,返回常数string::npos.如"s1.find("EF")"的结果为:4
rfind(s) //同find,但从后往前进行查找。如"s1.find("BCD")"的结果为:1
find_first_of(s) //在当前串中查找子串s第一次出现的位置
find_last_of(s) //在当前串中查找子串s最后一次出现的位置
replace(n1,n,s) //替换当前字符串中的字符,n1是替换的起始下标,n是要替换的字符个数,s是用来 替换的字符串
replace(n1,n,s,n2,m) //n1是替换的起始下标,n是替换掉的字符个数,s是用来替换的字符串,n2 是s中用来替换的起始下标,m是s中用于替换的字符的个数. 如"s1.replace(2,3,s2,2,3)"的结果为:s1="AB234FH"
insert(n,s) //在当前串的下标位置n之前,插入s串. 如“s1.insert(2,"88888”)"的结果 为:s1="AB88888CDEFH"
insert(n1,s,n2,m) //在当前串的n1下标后插入s串,n2是s串中要插入的起始下标,m是s串中要插 入的字符个数。如"s1.insert(2,s2,3,2)"的结果为:s1="AB34CDEFH"
简例:
#include<bits/stdc++.h>
using namespace std;
//typedef long long ll;
int main()
{
string s1="中华人民共和国成立了";
string s2="中国人民从此站起来了!";
string s3,s4,s5;
s3=s1+","+s2;
int n=s1.find_first_of("人民");
if(n!=string::npos)
cout<<"人民在s1中的位置: "<<n<<endl;
else
cout<<"在s1中没有该子串!"; //npos是没有找到时的函数返回值
s4=s1.substr(4,10); //一个汉字占两个字节
cout<<"s1= "<<s1<<endl;
cout<<"s2= "<<s2<<endl;
cout<<"s3= "<<s3<<endl;
cout<<"s4= "<<s4<<endl;
if(s1>s2)
cout<<"s1>s2= true"<<endl;
else
cout<<"s1>s2= false"<<endl;
s3.replace(s3.find("从此"),4,"从1949年");
cout<<"s3 after replace= "<<s3<<endl;
s3.insert(s3.find("站"),"10月");
cout<<"s3 after insert= "<<s3<<endl;
return 0;
}
输出:
人民在s1中的位置: 4
s1= 中华人民共和国成立了
s2= 中国人民从此站起来了!
s3= 中华人民共和国成立了,中国人民从此站起来了!
s4= 人民共和国
s1>s2= true
s3 after replace= 中华人民共和国成立了,中国人民从1949年站起来了!
s3 after insert= 中华人民共和国成立了,中国人民从1949年10月站起来了!