各位CSDN的uu们你们好呀,这段时间小雅兰的内容仍然是C++string类的使用的内容,下面,让我们进入string类的世界吧!!!
string类的常用接口说明
string类的常用接口说明
string类对象的修改操作
insert
data:image/s3,"s3://crabby-images/870ff/870ff1b6b535e6916ccdbb500fd4df30a7b9cfdf" alt=""
这是在第五个位置插入xxxx这个字符串!
data:image/s3,"s3://crabby-images/a911b/a911bee39c2d1cef79d21e01e32b67938342d485" alt=""
下面的代码的意思是头插4个x字符!
头插还可以这么写,用迭代器的方式!
cpp
#include<iostream>
#include<string>
using namespace std;
int main()
{
string s1("hello world");
s1.insert(5, "xxxx");
cout << s1 << endl;
s1.insert(0, 4, 'x');
cout << s1 << endl;
s1.insert(s1.begin(), 'z');
cout << s1 << endl;
return 0;
}
insert最常见的用法还是插入字符和插入字符串!
严格来说,对于string类,insert是能少用就少用!
erase
data:image/s3,"s3://crabby-images/921f7/921f7ecf7d98d0edcc95d6bd525d9d851a73475e" alt=""
下面两段代码的意思是:从第五个位置开始,删除四个字符
从第五个位置开始,后面有多少个字符就删多少个字符!
assign
data:image/s3,"s3://crabby-images/18c57/18c57b98831a7f95ece498efe0a383f657a17be6" alt=""
data:image/s3,"s3://crabby-images/a4b87/a4b87acaa08def9d1a797298d21c721583ba789a" alt=""
cpp
#include<iostream>
#include<string>
using namespace std;
int main()
{
string s1("hello world");
s1.assign(s1);
cout << s1 << endl;
s1.assign(s1, 4, 7);
cout << s1 << endl;
s1.assign("pangrams are cool", 8);
cout << s1 << endl;
s1.assign("C-string");
cout << s1 << endl;
return 0;
}
data:image/s3,"s3://crabby-images/5b68e/5b68e4e23047860bfb07a33b0d3bb80d5d4c6042" alt=""
replace
data:image/s3,"s3://crabby-images/53eb0/53eb081f6c93c486a9d3742dafc48ed9c58f4666" alt=""
data:image/s3,"s3://crabby-images/53e6a/53e6a17abe65e49ce3c2d0f170b2dcffd97f2310" alt=""
cpp
#include<iostream>
#include<string>
using namespace std;
int main()
{
string s1("hello world hello lsy");
cout << s1 << endl;
//所有的空格替换成%20
size_t pos = s1.find(' ');
while (pos != string::npos)
{
s1.replace(pos, 1, "%20");
pos = s1.find(' ');
}
cout << s1 << endl;
return 0;
}
data:image/s3,"s3://crabby-images/1fea9/1fea9e57fb1126c448bdc0f73facef79b7ae6ca0" alt=""
以前在学习C语言的时候,就写过程序实现这个功能,只是那时候还颇为复杂,学习了C++的string类之后,就简单多了,但是,这个程序写得还是不够好!
真正的问题是:每次find都要从头开始find,这样显然是没有必要的!
这样写就好多了!
int main()
{
string s1("hello world hello lsy");
cout << s1 << endl;//所有的空格替换成%20
size_t pos = s1.find(' ', 0);
while (pos != string::npos)
{
s1.replace(pos, 1, "%20");
pos = s1.find(' ', pos + 3);
}
cout << s1 << endl;
return 0;
}
data:image/s3,"s3://crabby-images/5215d/5215dabfa7c4104b7ca6541a88a7fd97f0df10f5" alt=""
但是实际上,这个程序还是不会这样写,因为replace要挪动数据,效率是很低的!
下面,小雅兰就给大家介绍一种高效率的写法:
cpp
int main()
{
string s1("hello world hello lsy");
cout << s1 << endl;
//所有的空格替换成%20
size_t pos = s1.find(' ', 0);
while (pos != string::npos)
{
s1.replace(pos, 1, "%20");
//效率很低,能不用就不要用了
pos = s1.find(' ', pos + 3);
}
cout << s1 << endl;
string s2("hello world hello lsy");
cout << s2 << endl;
string s3;
for (auto ch : s2)
{
if (ch == ' ')
{
s3 += "%20";
}
else
{
s3 += ch;
}
}
cout << s3 << endl;
s2.swap(s3);
cout << s2 << endl;
return 0;
}
data:image/s3,"s3://crabby-images/f088d/f088dcd12f08e2024d1eac4151be3a654d4dc368" alt=""
swap
不过,swap是不一样的!
第一个swap会产生临时对象,会有拷贝,效率没那么高,第二个swap就是直接交换了指针!
第二种写法的唯一缺陷就是消耗了空间!
pop_back
data:image/s3,"s3://crabby-images/5ceeb/5ceeb9a3d00abfddebd307d10ee4f060f31a2a7f" alt=""
c_str
data:image/s3,"s3://crabby-images/6ab50/6ab509a61a8c77e3869fb2e334127c4655643ba4" alt=""
#define _CRT_SECURE_NO_WARNINGS 1
#include<iostream>
#include<string>
using namespace std;int main()
{
string filename("test20240124.cpp");
FILE* fout = fopen(filename.c_str(), "r");
char ch = fgetc(fout);
while (ch != EOF)
{
cout << ch;
ch = fgetc(fout);
}return 0;
}
这个接口的主要目的就是兼容C!
这个程序就把小雅兰今天在文件中写的代码全部读取到控制台啦!
find+substr
data:image/s3,"s3://crabby-images/4a0db/4a0dbd53347eb02df3f8bab648727bb1cd4b0f9a" alt=""
要取一个文件的后缀:
cpp
int main()
{
string s1("Test.cpp");
string s2("Test.zip");
size_t pos1 = s1.find('.');
if (pos1 != string::npos)
{
string suff = s1.substr(pos1, s1.size() - pos1);
//string suff = s1.substr(pos1);
cout << suff << endl;
}
size_t pos2 = s2.find('.');
if (pos2 != string::npos)
{
string suff = s2.substr(pos2);
cout << suff << endl;
}
return 0;
}
data:image/s3,"s3://crabby-images/88152/881525d41874ab32dfb0afacffad810a9c6cd3f9" alt=""
但是这样写有一点小问题:
int main()
{
string s1("Test.cpp");
string s2("Test.tar.zip");size_t pos1 = s1.find('.');
if (pos1 != string::npos)
{
//string suff = s1.substr(pos1, s1.size() - pos1);
string suff = s1.substr(pos1);
cout << suff << endl;
}size_t pos2 = s2.find('.');
if (pos2 != string::npos)
{
string suff = s2.substr(pos2);
cout << suff << endl;
}
return 0;
}
取到的不是真后缀!
data:image/s3,"s3://crabby-images/fb5d8/fb5d8b0ff2aa2ecc12edffa8b37d7053964f2c99" alt=""
data:image/s3,"s3://crabby-images/d371f/d371faeb5129eae4b6822fd5d81c79c0eb0fcdbd" alt=""
cpp
int main()
{
string s1("Test.cpp");
string s2("Test.tar.zip");
size_t pos1 = s1.rfind('.');
if (pos1 != string::npos)
{
//string suff = s1.substr(pos1, s1.size() - pos1);
string suff = s1.substr(pos1);
cout << suff << endl;
}
size_t pos2 = s2.rfind('.');
if (pos2 != string::npos)
{
string suff = s2.substr(pos2);
cout << suff << endl;
}
return 0;
}
data:image/s3,"s3://crabby-images/4a47f/4a47f006d2a43326d940899f556357588cc3bae0" alt=""
这样才是取到的正确的后缀!
接下来,来看一个更为复杂的场景:
给定一个网址,把它的三个部分分离!
cpp
string str("https://legacy.cplusplus.com/reference/string/string/substr/");
string sub1, sub2, sub3;
pos1 = str.find(':');
sub1 = str.substr(0, pos1 - 0);
cout << sub1 << endl;
pos2 = str.find('/', pos1 + 3);
sub2 = str.substr(pos1 + 3, pos2 - (pos1 + 3));
cout << sub2 << endl;
sub3 = str.substr(pos2 + 1);
cout << sub3 << endl;
data:image/s3,"s3://crabby-images/554e0/554e0cee43e9cf1f2ff13069176a9d34f8386252" alt=""
find_first_of
data:image/s3,"s3://crabby-images/57960/5796098d821ad0ecfb998b9e7524ec4d47505fc9" alt=""
#include<iostream>
#include<string>
using namespace std;int main()
{
std::string str("Please, replace the vowels in this sentence by asterisks.");
std::size_t found = str.find_first_of("aeiou");
while (found != std::string::npos)
{
str[found] = '*';
found = str.find_first_of("aeiou", found + 1);
}std::cout << str << '\n';
return 0;
}
find_last_of
#include<iostream>
#include<string>
using namespace std;void SplitFilename(const std::string& str)
{
std::cout << "Splitting: " << str << '\n';
std::size_t found = str.find_last_of("/\\");
std::cout << " path: " << str.substr(0, found) << '\n';
std::cout << " file: " << str.substr(found + 1) << '\n';
}int main()
{
std::string str1("/usr/bin/man");
std::string str2("c:\\windows\\winhelp.exe");SplitFilename(str1);
SplitFilename(str2);return 0;
}
find_first_not_of
data:image/s3,"s3://crabby-images/bad02/bad02a285ace439138c32c2654318d9b986a445b" alt=""
#include<iostream>
#include<string>
using namespace std;int main()
{
std::string str("look for non-alphabetic characters...");std::size_t found = str.find_first_not_of("abcdefghijklmnopqrstuvwxyz ");
if (found != std::string::npos)
{
std::cout << "The first non-alphabetic character is " << str[found];
std::cout << " at position " << found << '\n';
}return 0;
}
find_last_not_of
data:image/s3,"s3://crabby-images/7b630/7b63095e7b2ad2cd91b9284fa65944e372568d52" alt=""
#include<iostream>
#include<string>
using namespace std;int main()
{
std::string str("Please, erase trailing white-spaces \n");
std::string whitespaces(" \t\f\v\n\r");std::size_t found = str.find_last_not_of(whitespaces);
if (found != std::string::npos)
str.erase(found + 1);
else
str.clear(); // str is all whitespacestd::cout << '[' << str << "]\n";
return 0;
}
+
data:image/s3,"s3://crabby-images/e9e63/e9e63cfdd9f8147c99b39318dabda17b3ad16970" alt=""
cpp
int main()
{
string s1(" hello ");
string s2("world");
string ret1 = s1 + s2;
cout << ret1 << endl;
string ret2 = s1 + "xx";
cout << ret2 << endl;
string ret3 = "xx" + s1;
cout << ret3 << endl;
return 0;
}
data:image/s3,"s3://crabby-images/46f5e/46f5eb1eacb6198bb1c6981b8cc2c3ae9ad07eea" alt=""
字符串最后一个单词的长度
data:image/s3,"s3://crabby-images/304a8/304a8b2d1a1f58275a5921dee1abef7ebc3c7cb5" alt=""
但是这个题目有一个坑,就是:不管是scanf还是cin,默认是用空格或者换行去分割!
data:image/s3,"s3://crabby-images/0c2f4/0c2f4f8a68fa99ce8a084f08fb8fdbf41df57b1f" alt=""
cpp
#include <iostream>
using namespace std;
#include<string>
int main()
{
string str;
getline(cin,str);
size_t pos=str.rfind(' ');
if(pos!=string::npos)
{
cout<<str.size()-(pos+1)<<endl;
}
else
{
cout<<str.size()<<endl;
}
return 0;
}
data:image/s3,"s3://crabby-images/f3a49/f3a49e95a7e7041e348307ab3a461e791f03e9c5" alt=""
好啦,string的使用的部分到这里就结束啦,之前的文章:
https://xiaoyalan.blog.csdn.net/article/details/135110694?spm=1001.2014.3001.5502
https://xiaoyalan.blog.csdn.net/article/details/135133181?spm=1001.2014.3001.5502
还要继续加油!!!
data:image/s3,"s3://crabby-images/ad180/ad180e5a6eed25658327fb02d46c4b1f4d32f2cb" alt=""