文章目录
============================ 【说明】 ===================================================
大家好,本专栏主要是跟学C++内容,自己学习了这位博主【 AI菌】的【C++21天养成计划】,讲的十分清晰,适合小白,希望给这位博主多点关注、收藏、点赞。
主要针对所学内容,通过自己的理解进行整理,希望大家积极交流、探讨,多给意见。后面也会给大家更新,其他一些知识。若有侵权,联系删除!共同维护网络知识权利!
=======================================================================================
1、String类优点
在C++语言中,字符串是一个字符数组,最简单的静态字符数组可以这样定义:
//定义了一个长度为10的静态字符数组
char Array[10];
在实际应用中,我们定义的字符数组长度是无法确定的,我们更希望像动态数组vector
那样,声明一个动态字符数组,根据程序需要,动态调整长度。
C++中,String类就提供了这样的方法,除了提供了动态调字符整数组大小的功能,还有很多有用的成员函数(方法),操作更加便利。
2、初始化
String类提供了很多重载的构造函数,因此可以使用多种方式进行初始化和实例化:
#include <iostream>
#include <string>
using namespace std;
int main() {
//定义字符数组的多种方式
string str1 = "hello1!";
string str2("hello2!");
//将str1复制到str3
string str3(str1);
//输出8个C
string str4(8,'C');
cout << "str1:"<<str1 << endl;
cout << "str2:" << str2 << endl;
cout << "str3:" << str3 << endl;
cout << "str4:" << str4 << endl;
return 0;
}
3、访问字符串
访问方式和数组很类似,一种是利用索引方式,另一种利用迭代器。
#include <iostream>
#include <string>
using namespace std;
int main() {
string s1 = "Welcome back!";
cout << "---索引方式访问---"<<endl;
for (int i = 0; i < s1.length(); i++)
{
cout << "s1[" << i << "] is:" << s1[i] << endl;
}
cout << "---迭代器方式访问---" << endl;
int offset = 0;
string::const_iterator Locator;
for (Locator = s1.begin() ; Locator != s1.end(); Locator++) {
cout << "s1[" << offset++ << "] is:" << *Locator << endl;
}
return 0;
}
4、String类字符串函数
字符串常见的函数有:复制、拼接、查找、截断、反转、大小写转换等,简单熟悉一下各个函数的使用方法。
4.1 append()拼接
将两个字符串进行拼接,既可以使用+=
的方式,也可以使用这里的函数append()
。
#include <iostream>
#include <string>
using namespace std;
int main() {
string s1 = "I like";
string s2 = " CPP! ";
//方法1:+=
s1 += s2;
cout << "s1+=s2: " << s1 << endl;
//方法2:append()
string s3 = "CPP is the best language!";
s1.append(s3);
cout << "s1.append(s3): " << s1 << endl;
return 0;
}
4.2 find()查找字符或子串
查找字符串中的字符或者子串,基本格式为:
//在字符串str中查找字符s2,从n号位开始寻找,返回pos
int pos=str.find(s2,n);
int main() {
string s1 = "CPP is the best language";
cout << "s1:" << s1 <<endl;
rsize_t position = s1.find("best", 0);
if (position!=string::npos)//string::npos值为-1,表示未找到要找的字符
cout << "字符串第一次出现的位置为:" << position << endl;
else
cout << "字符串没有找到" <<endl;
//返回所有子字符串的位置
cout << "字符串best出现的所有位置:";
size_t all_pos = s1.find("best", 0);
while (all_pos != string::npos)
{
cout << all_pos << " ";
size_t search_pos = all_pos + 1;
all_pos = s1.find("best", search_pos); //返回子字符串出现的位置
}
return 0;
}
4.3 erase()截断字符串
(1) 给定偏移位置(删除的起始位置)和要删除的字符个数。
string s1 = "I love you very much!"
s1.erase(2,4); //从索引号2开始,删除4个字符,即删掉love。
(2) 在给定指向字符的迭代器时删除该字符
//删除字符串s1中的所有的字符'I'
#include<iostream>
#include<string>
#include<algorithm>
using namespace std;
int main()
{
string s1("I love you! and do you love me?");
string::iterator pos = find(s1.begin(),s1.end(),'I'); //找到字符'I'的位置给迭代器
if(pos!=s1.end())
s1.erase(pos); //依次删除迭代器指向的字符
cout<<s1<<endl;
return 0;
}
(3) 在给定两个迭代器指定的范围时,删除该范围内的字符
s1.erase(s1.begin(),s1.end());
4.4 reverse()字符串反转
所谓反转,就是首位倒序存放。比如要判断某字符串是否是回文串,就可以将其反转,再与原来的字符串进行比较。
#include<iostream>
#include<string>
#include<algorithm>
using namespace std;
int main()
{
string s1("I love you!");
reverse(s1.begin(),s1.end()); //将s1进行反转
cout<<s1;
return 0;
}
4.5 transform()大小写转换
//1.将字符串s1转换为大写
transform(s1.begin(),s1.end(),s1.begin(),toupper);
//2.将字符串s1转化为小写
transform(s1.begin(),s1.end(),s1.begin(),tolower);
#include<iostream>
#include<string>
#include<algorithm>
using namespace std;
int main(){
string s1("cpp best");
//前2个指定要转换的容器的起止范围,
//第3个参数是结果存放容器的起始位置,
//第四个参数表示反转运算
transform(s1.begin(), s1.end(), s1.begin(), toupper);
cout << s1;
return 0;
}
5、总结
最后,长话短说,大家看完就好好动手实践一下,切记不能三分钟热度、三天打鱼,两天晒网。大家也可以自己尝试写写博客,来记录大家平时学习的进度,可以和网上众多学者一起交流、探讨,我也会及时更新,来督促自己学习进度。一开始提及的博主【AI菌】,个人已关注,并订阅了相关专栏(对我有帮助的),希望大家觉得不错的可以点赞、关注、收藏