>>>>>
需要引入#include <string>
#include <iostream>
#include <string>
int main()
{
/*
* 特点:
* 1.不存在内存溢出
* 2.本质是对char的封装
*/
std::string str1{ "我是string字符串" };
std::string str2{ "666" };
std::string str3 = str1 + str2;// 字符串拼接
std::cout << str3 << std::endl;
std::string str31 = "字符串1" "字符串2" "字符串3";// 字符串拼接2
std::cout << str31 << std::endl;
str31.append("。嘿嘿。").append("我能无限拼接。").append("我能截取字符串【单字节】。", 2);// 字符串拼接3
std::cout << str31 << std::endl;
std::string str32 = str31.substr(2, 4);// str31.substr(起始位置, 截取长度)。返回新的str,不改变原str。
std::cout << str32 << std::endl;
std::string str4{ "我是字符串",3 };// 截取3个字节长度的字符串【单字节】,3只能截到“我”
std::string str5(6, 'a');// 初始化字符串,值为'aaaaaa'
std::cout << str5 << std::endl;
// std::to_string(数字)// 数字转字符串
std::string str6{ "用户年龄是:" + std::to_string(-1) };// 需要引入#include <string>
std::cout << str6 << std::endl;
std::string str7{ "字符串数量A中英AA混合不灵" };// 需要引入#include <string>
std::cout << "字符串长度:" << str7.length() << std::endl;
str7.find("A");// find返回找到的第一个该字符串所在的位置【单字节
std::cout << "find返回:" << str7.find("A") << std::endl;
// 如果没找到则返回std::string::npos
if (str7.find("b") == std::string::npos)
std::cout << "字符串没找到" << std::endl;
// 字符串插入insert(起始位置, "要插入的字符串",参数2截取的起始位置的后一个位置 ,参数2截取的长度)
std::string str8{ "id=;" };
str8.insert(3, "666");//得到id=666;
str8.insert(3, "999",1 ,1);//得到id=9666;
std::cout << str8 << std::endl;
// 字符串替换replace(要替换的内容起始位置, 要替换的长度, 替换后的内容)
std::string str9{"字符串替换"};
str9.replace(2, 2, "【被替换内容】");// str9值为“字【被替换内容】串替换”
std::cout << str9 << std::endl;
// 字符串内容擦除erase(要删除的起始位置,要删除的起始长度)
str9.erase(2, 2);// str9值为“字被替换内容】串替换”
str9.erase();// 全部擦除
str9.clear();// 全部擦除
}
实操:求string字符串长度
原理:if(字符>0 && 字符<127) 是英文
std::string str10{ "你好123" };
int length = 0;
for (int i = 0; str10[i];i++) {
if (str10[i] < 0)i++;
length++;
}
std::cout << "字符串长度" << length << std::endl;
字符串转数字
stringstream字符串流
>>>>>