C++ String类介绍

1.对象初始化

string s("hello");
string s = "hello";
string s(8,'x');

将字符赋值给string对象的方法:

string s;
s = 'n';

2.相关操作及成员函数

1)长度
int len = s.length();
int len = s.size();
2)读取

支持流读取运算符

cin>>s;//遇到空格或换行符截止读取

支持getline函数

getline(cin,s);//读取一整行到string对象,遇到换行符读取截止
3)复制

可用“=”进行赋值
可用成员函数assign

s.assign(s1);//全部复制
s.assign(s1, 1, 3);//部分复制,从s1中下标为1的字符开始复制3个字符
4)连接字符串

可用“+”运算符进行连接
可用成员函数append

s.append(s1);//将s1添加到s到末尾
s.append(s1,3,s1.size());
//下标为3开始,s1.size()个字符添加到s的末尾,若没有足够字符,则复制到字符串最后一个字符;
5)比较大小

可用运算符== < > !=
可用成员函数compare

int f = s.compare(s1);
/*** 0 == 1 > -1 < ***/
int f = s.compare(1,2,s1,0,3);//s的下标从1开始的2个字符串与s1的下标从0开始的3个字符串进行比较
6)求子串
s.substr(4,5);//下标从4开始的5个字符
7)交换string
s.swap(s2);
8)查找
s1.find("lo");
//从前向后查找“lo”第一次出现的地方,若找到返回“lo”开始的位置下标整型,若找不到,返回string::npos
s1.rfind("lo");
//从后往前找
s1.find("lo",1);
//从下标为1的地方开始找
s.find_first_of(“abcd”); 
//从前向后找,“abcd”中任何一个字符第一次出现的地方,若找到,返回下标,若找不到,返回string::npos
s.find_last_of(“abcd”); 
//从前向后找,“abcd”中任何一个字符最后一次出现的地方,若找到,返回下标,若找不到,返回string::npos
s.find_first_of(“abcd”); 
//从前向后找,不在“abcd”中任何一个字符第一次出现的地方,若找到,返回下标,若找不到,返回string::npos
9)删除字符
s.erase(5); //删除下标为5之后的字符
10)替换字符
s.replace(2,3,"haha");//将s中下标为2开始的3个字符替换成“haha”
11)插入字符
s.insert(5,s1);//将s1插入到s下标为5的位置
s.insert(2,s1,5,3);//将s1中下标为5开始的3个字符插入到s的下标为2的位置
12) 转换成C语言式char *字符串
s.c_str();
//返回传统的const char *类型字符串,且该字符串以'\0'结尾。
s.data();
//返回传统的char *类型字符串

3 字符串流处理

类似istream和ostream进行标准流输入输出,我们用istringstream和ostringstream进行字符串上的输入输出,也称为内存输入输出。
头文件申明为:

#include <string>
#include <iostream>
#include <sstream>
全部评论

相关推荐

07-15 14:14
门头沟学院 Java
7.10投递7.15感谢信
投递地平线等公司8个岗位
点赞 评论 收藏
分享
06-10 21:15
门头沟学院 Java
宁阿:好多这种没🧠的公司,他们估计都不知道毕业的人不能给安排实习岗
实习吐槽大会
点赞 评论 收藏
分享
不愿透露姓名的神秘牛友
07-16 14:00
机械打工仔:来挂自己了,经典巨婴从校园投入职场
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务