C++中查找子串主要使用std::string的find()函数,1. find()返回子串首次出现位置,未找到则返回npos;2. 可指定起始位置查找多个匹配项;3. rfind()从右查找最后一次出现位置;4. 注意size_t类型、检查npos及大小写敏感问题。

在C++中查找字符串中的子串是日常编程中常见的操作。C++标准库提供了多种方法来实现这一功能,主要依赖于std::string类自带的成员函数。本文将介绍几种常用的字符串查找方式,帮助你高效地完成子串搜索任务。
1. 使用 find() 函数查找子串
find() 是最常用的字符串查找函数,用于在原字符串中搜索指定的子串或字符。如果找到,返回子串首次出现的起始位置(索引);如果未找到,返回 std::string::npos。
基本语法:
size_t pos = str.find("substring");
立即学习“C++免费学习笔记(深入)”;
示例代码:
#include iostream>
#include
int main() {
std::string text = "Hello, welcome to C++ programming!";
std::string pattern = "welcome";
size_t pos = text.find(pattern);
if (pos != std::string::npos) {
std::cout
} else {
std::cout
}
return 0;
}
2. 从指定位置开始查找
find() 还支持从某个指定位置开始搜索,适用于需要查找多个匹配项的情况。
语法:
str.find(substring, start_pos);
示例:查找所有匹配的子串位置
std::string text = "She sells seashells by the seashore.";
std::string pattern = "se";
size_t pos = 0;
while ((pos = text.find(pattern, pos)) != std::string::npos) {
std::cout
pos += pattern.length(); // 避免重复查找同一位置
}
3. 其他查找函数简介
C++还提供了其他几个查找函数,满足不同需求:
- rfind():从右往左查找,返回最后一个匹配的起始位置。
- find_first_of():查找任意一个属于指定字符集合的字符首次出现的位置。
- find_last_of():查找任意一个属于集合的字符最后一次出现的位置。
- find_first_not_of() 和 find_last_not_of():查找不在指定集合中的字符。
例如使用 rfind() 查找最后一次出现的子串:
size_t pos = text.rfind("sea");
if (pos != std::string::npos) {
std::cout
}
4. 注意事项与建议
使用字符串查找函数时需注意以下几点:
- 返回值类型是 size_t,不是 int,避免类型转换错误。
- 始终检查是否等于 std::string::npos 来判断查找结果。
- find() 区分大小写,如需忽略大小写,需自行转换为统一格式后再查找。
- 若频繁进行复杂模式匹配,可考虑使用
正则表达式库。
基本上就这些。熟练掌握 find 及其相关函数,能让你在处理文本时更加得心应手。不复杂但容易忽略细节,比如 npos 的判断和查找起点控制。多练习几种场景,就能灵活运用了。










