C语言和C++语言中 string类详解文档格式.docx
《C语言和C++语言中 string类详解文档格式.docx》由会员分享,可在线阅读,更多相关《C语言和C++语言中 string类详解文档格式.docx(11页珍藏版)》请在冰点文库上搜索。
变量s1只是定义但没有初始化,编译器会将默认值赋给s1,默认值是"
"
,也即空字符串。
变量s2在定义的同时被初始化为"
。
与C风格的字符串不同,string的结尾没有结束标志'
\0'
变量s3在定义的时候直接用s2进行初始化,因此s3的内容也是"
变量s4被初始化为由5个'
字符组成的字符串,也就是"
sssss"
从上面的代码可以看出,string变量可以直接通过赋值操作符=进行赋值。
string变量也可以用C风格的字符串进行赋值,例如,s2是用一个字符串常量进行初始化的,而s3则是通过s2变量进行初始化的。
与C风格的字符串不同,当我们需要知道字符串长度时,可以调用string类提供的length()函数。
如下所示:
voidmain()
{
stringx="
helloworld"
cout<
<
x.length()<
endl;
system("
pause"
return;
输出结果为11。
由于string的末尾没有'
字符,所以length()返回的是字符串的真实长度,而不是长度+1。
转换为C风格的字符串
虽然C++提供了string类来替代C语言中的字符串,但是在实际编程中,有时候必须要使用C风格的字符串(例如打开文件时的路径),为此,string类为我们提供了一个转换函数c_str(),该函数能够将string字符串转换为C风格的字符串,并返回该字符串的const指针(constchar*)。
请看下面的代码:
stringpath="
D:
\\demo.txt"
FILE*fp=fopen(path.c_str(),"
rt"
为了使用C语言中的fopen()函数打开文件,必须将string字符串转换为C风格的字符串。
string字符串的输入输出
string类重载了输入输出运算符,可以像对待普通变量那样对待string变量,也就是用>
>
进行输入,用<
进行输出。
strings;
cin>
s;
//输入字符串
cout<
s<
endl;
//输出字符串
运行结果:
Helloworld!
↙(输入)
Hello(输出)
虽然我们输入了两个由空格隔开的单词,但是只输出了一个,这是因为输入运算符>
默认会忽略空格,遇到空格就认为输入结束,所以最后输入的world!
没有被存储到变量s。
访问字符串中的字符
string字符串也可以像C风格的字符串一样按照下标来访问其中的每一个字符。
string字符串的起始下标仍是从0开始。
strings="
1234567890"
for(inti=0,len=s.length();
i<
len;
i++){
s[i]<
"
}
s[5]='
5'
1234567890
1234557890
本例定义了一个string变量s,并赋值"
,之后用for循环遍历输出每一个字符。
借助下标,除了能够访问每个字符,也可以修改每个字符,s[5]='
就将第6个字符修改为'
,所以s最后为"
1234557890"
字符串的拼接
有了string类,我们可以使用+或+=运算符来直接拼接字符串,非常方便,再也不需要使用C语言中的strcat()、strcpy()、malloc()等函数来拼接字符串了,再也不用担心空间不够会溢出了。
用+来拼接字符串时,运算符的两边可以都是string字符串,也可以是一个string字符串和一个C风格的字符串,还可以是一个string字符串和一个字符数组,或者是一个string字符串和一个单独的字符。
请看下面的例子:
strings1="
first"
second"
char*s3="
third"
chars4[]="
fourth"
charch='
@'
strings5=s1+s2;
strings6=s1+s3;
strings7=s1+s4;
strings8=s1+ch;
s5<
endl<
s6<
s7<
s8<
firstsecond
firstthird
firstfourth
first@
string字符串的增删改查
C++提供的string类包含了若干实用的成员函数,大大方便了字符串的增加、删除、更改、查询等操作。
一.插入字符串
insert()函数可以在string字符串中指定的位置插入另一个字符串,它的一种原型为:
string&
insert(size_tpos,conststring&
str);
pos表示要插入的位置,也就是下标;
str表示要插入的字符串,它可以是string字符串,也可以是C风格的字符串。
strings1,s2,s3;
s1=s2="
s3="
aaa"
s1.insert(5,s3);
s1<
s2.insert(5,"
bbb"
s2<
12345aaa67890
12345bbb67890
insert()函数的第一个参数有越界的可能,如果越界,则会产生运行时异常。
二.删除字符串
erase()函数可以删除string中的一个子字符串。
它的一种原型为:
erase(size_tpos=0,size_tlen=npos);
pos表示要删除的子字符串的起始下标,len表示要删除子字符串的长度。
如果不指明len的话,那么直接删除从pos到字符串结束处的所有字符(此时len=str.length-pos)。
s1=s2=s3="
s2.erase(5);
s3.erase(5,3);
s3<
1234567890
12345
1234590
有读者担心,在pos参数没有越界的情况下,len参数也可能会导致要删除的子字符串越界。
但实际上这种情况不会发生,erase()函数会从以下两个值中取出最小的一个作为待删除子字符串的长度:
len的值;
字符串长度减去pos的值。
说得简单一些,待删除字符串最多只能删除到字符串结尾。
三.提取子字符串
substr()函数用于从string字符串中提取子字符串,它的原型为:
stringsubstr(size_tpos=0,size_tlen=npos)const;
pos为要提取的子字符串的起始下标,len为要提取的子字符串的长度。
firstsecondthird"
strings2;
s2=s1.substr(6,6);
firstsecondthird
second
系统对substr()参数的处理和erase()类似:
如果pos越界,会抛出异常;
如果len越界,会提取从pos到字符串结尾处的所有字符。
四.
字符串查找
string类提供了几个与字符串查找有关的函数,如下所示。
1)find()函数
find()函数用于在string字符串中查找子字符串出现的位置,它其中的两种原型为:
size_tfind(conststring&
str,size_tpos=0)const;
size_tfind(constchar*s,size_tpos=0)const;
第一个参数为待查找的子字符串,它可以是string字符串,也可以是C风格的字符串。
第二个参数为开始查找的位置(下标);
如果不指明,则从第0个字符开始查找。
second"
intindex=s1.find(s2,5);
if(index<
s1.length())
Foundatindex:
index<
else
Notfound"
6
find()函数最终返回的是子字符串第一次出现在字符串中的起始下标。
本例最终是在下标6处找到了s2字符串。
如果没有查找到子字符串,那么会返回一个无穷大值4294967295。
2)rfind()函数
rfind()和find()很类似,同样是在字符串中查找子字符串,不同的是find()函数从第二个参数开始往后查找,而rfind()函数则最多查找到第二个参数处,如果到了第二个参数所指定的下标还没有找到子字符串,则返回一个无穷大值4294967295。
intindex=s1.rfind(s2,6);
3)find_first_of()函数
find_first_of()函数用于查找子字符串和字符串共同具有的字符在字符串中首次出现的位置。
firstsecondsecondthird"
asecond"
intindex=s1.find_first_of(s2);
3
本例中s1和s2共同具有的字符是’s’,该字符在s1中首次出现的下标是3,故查找结果返回3。