基于算法竞赛的c++编程(18)string类细节问题

本节是string类细节问题

构造与初始化

std::string有多种构造函数:

cpp 复制代码
std::string s1;                // 默认构造,空字符串
std::string s2("Hello");       // 从C字符串构造
std::string s3(s2);            // 拷贝构造
std::string s4(5, 'a');        // 填充构造,结果为"aaaaa"
std::string s5(s2, 1, 3);      // 子串构造,从索引1开始取3个字符,结果为"ell"

访问字符

可用[]at()访问字符:

cpp 复制代码
std::string s = "Hello";
char c1 = s[1];      // 'e',不检查边界
char c2 = s.at(1);   // 'e',抛出std::out_of_range异常

修改操作

追加、插入、删除等操作:

cpp 复制代码
s += " World";       // 追加,s变为"Hello World"
s.append("!");       // 追加,s变为"Hello World!"
s.insert(5, ",");    // 插入,s变为"Hello, World!"
s.erase(5, 1);       // 删除,s变为"Hello World!"

查找与替换

查找子串或字符:

cpp 复制代码
size_t pos = s.find("World");  // 返回首次出现的位置(6)
if (pos != std::string::npos) {
    s.replace(pos, 5, "C++");  // 替换为"C++",s变为"Hello C++!"
}

容量与大小

cpp 复制代码
s.size();     // 当前字符数(9)
s.empty();    // 是否为空
s.resize(10); // 调整大小,不足时填充'\0'
s.capacity(); // 当前分配的内存容量

字符串比较

直接使用比较运算符:

cpp 复制代码
std::string a = "apple", b = "banana";
if (a < b) { /* ... */ }  // 字典序比较

转换与C字符串

转换为C风格字符串:

cpp 复制代码
const char* cstr = s.c_str();  // 返回const char*
char* buf = new char[s.size() + 1];
s.copy(buf, s.size());         // 拷贝到缓冲区

迭代器支持

支持STL迭代器:

cpp 复制代码
for (auto it = s.begin(); it != s.end(); ++it) {
    std::cout << *it;
}
for (char ch : s) { /* ... */ }  // 范围for循环

注意:std::string管理的内存是动态分配的,无需手动释放。C++17后新增了std::string_view用于非占有式字符串视图。

相关推荐
qq_417695052 分钟前
基于C++的区块链实现
开发语言·c++·算法
电商API_180079052473 分钟前
电商平台公开数据采集实践:基于合规接口的数据分析方案
开发语言·数据库·人工智能·数据挖掘·数据分析·网络爬虫
小陈工4 分钟前
2026年3月22日技术资讯洞察:数据库优化进入预测时代,网络安全威胁全面升级
java·开发语言·数据库·python·安全·web安全·django
We་ct4 分钟前
LeetCode 74. 搜索二维矩阵:两种高效解题思路
前端·算法·leetcode·矩阵·typescript·二分查找
2401_894241925 分钟前
基于C++的反射机制探索
开发语言·c++·算法
xyq20248 分钟前
ionic 单选框详解
开发语言
cui_ruicheng8 分钟前
C++ 数据结构进阶:unordered_map 与 unordered_set源码分析与实现
数据结构·c++·算法·哈希算法
天赐学c语言10 分钟前
Linux - 网络应用层协议HTTP
linux·c++·网络服务
C蔡博士13 分钟前
最小生成树(MST)详解:定义、算法与核心性质
算法·贪心算法·图论·时间复杂度
wWYy.13 分钟前
STL:map与unordered_map
开发语言·c++·stl