C++中通过find_first_not_of和find_last_not_of实现字符串去空格,左trim从首个非空白字符截取,右trim截取到最后一个非空白字符,完整trim结合两者逻辑,支持空格、制表符、换行符等,示例代码展示对" \t Hello World \n\r "处理后输出[Hello World]。

在C++中,标准库std::string没有提供内置的trim方法来去除字符串首尾空格,但可以通过自定义函数实现。常用做法是利用find\_first\_not\_of和find\_last\_not\_of定位非空白字符的位置,然后使用substr提取有效部分。
去除首部空格(左trim)
通过find\_first\_not\_of查找第一个不是空格、制表符或换行符的字符位置,从该位置截取到末尾。
- 如果字符串全为空白,返回空字符串
- 否则返回从首个非空白字符开始的子串
示例代码:
std::string ltrim(const std::string& str) {
size_t start = str.find_first_not_of(" \t\n\r");
return start == std::string::npos ? "" : str.substr(start);
}去除尾部空格(右trim)
使用find\_last\_not\_of找到最后一个非空白字符的位置,截取从开头到该位置的部分。
立即学习“C++免费学习笔记(深入)”;
- 若无非空白字符,返回空字符串
- 否则保留从起始到最末非空白字符之间的内容
示例代码:
std::string rtrim(const std::string& str) {
size_t end = str.find_last_not_of(" \t\n\r");
return end == std::string::npos ? "" : str.substr(0, end + 1);
}同时去除首尾空格(完整trim)
先执行左trim得到去头结果,再对结果做右trim,或者合并逻辑一次完成。
推荐实现方式:
std::string trim(const std::string& str) {
size_t start = str.find_first_not_of(" \t\n\r");
size_t end = str.find_last_not_of(" \t\n\r");
if (start == std::string::npos)
return "";
return str.substr(start, end - start + 1);}
使用示例
调用上述函数可轻松处理带空白的字符串:
#include
#include
int main() {
std::string input = " \t Hello World \n\r ";
std::string result = trim(input);
std::cout << "[" << result << "]"; // 输出: [Hello World]
return 0;
}
基本上就这些。这个方法支持多种空白字符,逻辑清晰,效率也不错,适合日常使用。










