使用substr()函数可高效截取字符串,如str.substr(pos, len)从pos开始取len个字符,结合find()可动态定位并提取子串,如提取域名;需注意边界处理。

在C++中截取子字符串,最常用的方法是使用标准库 std::string 提供的 substr() 成员函数。这个方法简单高效,适用于大多数字符串处理场景。
使用 substr() 截取子串
substr() 函数定义在
string substr(size_t pos = 0, size_t len = npos) const;
- pos:起始位置(索引从0开始)
- len:要截取的字符个数,如果超出字符串末尾,则只取到结尾
- 返回一个新的 string 对象,不修改原字符串
示例代码:
立即学习“C++免费学习笔记(深入)”;
#include#include using namespace std; int main() { string str = "Hello, World!"; string sub1 = str.substr(7, 5); // 从第7个字符开始,取5个 cout << sub1 << endl; // 输出: World
string sub2 = str.substr(0, 5); // 取前5个字符 cout zuojiankuohaophpcnzuojiankuohaophpcn sub2 zuojiankuohaophpcnzuojiankuohaophpcn endl; // 输出: Hello string sub3 = str.substr(7); // 从第7个开始到结尾 cout zuojiankuohaophpcnzuojiankuohaophpcn sub3 zuojiankuohaophpcnzuojiankuohaophpcn endl; // 输出: World! return 0;}
结合 find() 动态定位并截取
实际开发中,常需要根据某个字符或子串的位置来截取。可以先用 find() 找到位置,再用 substr() 截取。
例如:提取 URL 中的域名
string url = "https://www.example.com/path";
size_t start = url.find("://") + 3; // 协议后开始
size_t end = url.find('/', start); // 下一个 '/' 位置
string domain = url.substr(start, end - start);
cout << domain << endl; // 输出: www.example.com
手动实现子串截取(如需学习原理)
虽然不推荐重复造轮子,但理解底层逻辑有助于掌握字符串操作。可以用循环和字符数组模拟:
string my_substr(const string& s, int pos, int len) {
string result = "";
int n = s.length();
for (int i = pos; i < pos + len && i < n; i++) {
result += s[i];
}
return result;
}
注意边界检查,避免越界访问。
基本上就这些。日常使用 substr() 完全够用,配合 find()、rfind()、find_first_of() 等查找函数能解决绝大多数子串提取需求。不复杂但容易忽略的是位置和长度的计算,建议加注释避免出错。











