C++ string类的成员函数解析与使用
ztj100 2025-01-03 20:48 20 浏览 0 评论
C++ 中的 std::string 类是一个功能强大的字符串处理类,它提供了丰富的成员函数来操作和管理字符串。以下是对 std::string 类中一些重要成员函数的深入理解:
构造函数
- 默认构造函数:创建一个空字符串。
- 参数化构造函数:接受 C 风格字符串(const char*)、字符串字面量、另一个 std::string 对象或字符串迭代器范围来初始化字符串。
基本操作
- size():返回字符串中的字符数(不包括结尾的空字符)。
- length():与 size() 相同,返回字符串的长度。
- empty():检查字符串是否为空。
- clear():清空字符串内容。
访问元素
- operator[]:通过索引访问字符串中的单个字符(返回引用,可以修改字符)。
- at():通过索引访问字符串中的单个字符(返回引用,但会进行范围检查,如果索引超出范围则抛出 std::out_of_range 异常)。
- front():返回字符串的第一个字符的引用。
- back():返回字符串的最后一个字符的引用。
字符串操作
- assign():用新内容替换当前字符串的内容。
- append():在字符串末尾追加内容。
- prepend()(C++20 引入的 std::string::operator+= 可以实现类似功能):在字符串开头添加内容(虽然 std::string 没有直接的 prepend 成员函数,但可以通过 operator+= 和反转字符串来实现)。
- replace():替换字符串中的部分内容。
- substr():返回字符串的一个子串。
- swap():交换两个字符串的内容。
查找与比较
- find():在字符串中查找子串或字符的首次出现位置。
- rfind():在字符串中查找子串或字符的最后一次出现位置。
- find_first_of():在字符串中查找第一次出现指定字符集中的任一字符的位置。
- find_last_of():在字符串中查找最后一次出现指定字符集中的任一字符的位置。
- find_first_not_of():在字符串中查找第一次不出现指定字符集中的任一字符的位置。
- find_last_not_of():在字符串中查找最后一次不出现指定字符集中的任一字符的位置。
- compare():比较两个字符串的字典顺序。
字符处理
- copy():将字符串的内容复制到字符数组中。
- c_str():返回一个指向以空字符结尾的字符数组的指针(C 风格字符串)。
- data():与 c_str() 类似,返回一个指向字符串内容的指针。
修改器
- push_back():在字符串末尾添加一个字符。
- pop_back():移除字符串末尾的字符。
- insert():在指定位置插入字符或子串。
- erase():移除指定位置的字符或子串。
- resize():改变字符串的大小。
其他
- reserve():请求改变容量大小。
- capacity():返回当前分配的容量。
- max_size():返回字符串能包含的最大字符数。
代码实例
#include <iostream>
#include <string>
int main() {
// 构造函数
std::string str1; // 默认构造函数,创建一个空字符串
std::string str2("Hello, World!"); // 参数化构造函数,用C风格字符串初始化
std::string str3(str2); // 拷贝构造函数,复制str2的内容到str3
std::string str4(str2.begin(), str2.begin() + 5); // 迭代器范围构造函数,取str2的前5个字符
// 基本操作
std::cout << "str2 size: " << str2.size() << std::endl; // 输出str2的长度,应为13
std::cout << "str2 empty: " << (str2.empty() ? "false" : "true") << std::endl; // 输出str2是否为空,应为false
str2.clear(); // 清空str2的内容
std::cout << "str2 empty after clear: " << (str2.empty() ? "true" : "false") << std::endl; // 输出清空后的str2是否为空,应为true
// 访问元素
std::cout << "str3[0]: " << str3[0] << std::endl; // 输出str3的第一个字符,应为'H'
try {
std::cout << "str3 at(10): " << str3.at(10) << std::endl; // 尝试输出str3的第11个字符,会抛出异常
} catch (const std::out_of_range& e) {
std::cout << "Caught exception: Index out of range" << std::endl; // 捕获并输出异常信息
}
std::cout << "str3 front: " << str3.front() << std::endl; // 输出str3的第一个字符,应为'H'
std::cout << "str3 back: " << str3.back() << std::endl; // 输出str3的最后一个字符,应为'!'(注意:这里str3未被修改过,所以仍然是'd')
// 字符串操作
str3.assign("New String"); // 将str3的内容设置为"New String"
str3.append(" Appended"); // 在str3末尾追加" Appended"
std::string prepended = "Prepended: " + str3; // 通过+运算符实现prepend效果
std::string str5 = "1234567890";
str5.replace(4, 3, "abc"); // 将str5中从第5个字符开始的3个字符替换为"abc"
std::string subStr = str5.substr(0, 5); // 从str5中提取前5个字符作为子串
std::string str6 = "Another String";
str3.swap(str6); // 交换str3和str6的内容
// 查找与比较
std::size_t pos = str6.find("String"); // 在str6中查找子串"String"的位置
std::cout << "Position of 'String' in str6: " << pos << std::endl; // 输出找到的位置,应为7(注意:这里str6已经被交换为"New String Appended")
std::cout << "str3 compare str6: " << (str3.compare(str6) == 0 ? "equal" : "not equal") << std::endl; // 比较str3和str6,输出是否相等(这里应该不相等,因为str3现在是"Another String")
// 注意:下面的输出将基于已经被修改的str3和str6
// 字符处理
char buffer[20];
str3.copy(buffer, 10); // 将str3的前10个字符复制到buffer中
std::cout << "Copied string: " << buffer << std::endl; // 输出复制的字符串(注意:可能包含垃圾字符,因为buffer未完全初始化)
const char* cStr = str3.c_str(); // 获取str3的C风格字符串表示
std::cout << "C-style string: " << cStr << std::endl; // 输出C风格字符串
// 修改器
str3.push_back('!'); // 在str3末尾添加'!'
str3.pop_back(); // 移除str3末尾的字符(刚刚添加的'!')
str3.insert(0, "Inserted: "); // 在str3开头插入"Inserted: "
str3.erase(0, 9); // 移除str3的前9个字符(包括刚刚插入的"Inserted: "的前8个字符和原字符串的第一个字符)
str3.resize(5); // 将str3的大小调整为5个字符,如果不够则截断,如果够则可能填充垃圾字符(取决于实现)
// 注意:由于上面的修改,下面的输出将反映这些变化
// 其他
str3.reserve(100); // 请求改变str3的容量至少为100个字符
std::cout << "Capacity of str3: " << str3.capacity() << std::endl; // 输出str3的当前容量(可能大于或等于100)
std::cout << "Max size of str3: " << str3.max_size() << std::endl; // 输出str3能包含的最大字符数(通常是一个非常大的数)
return 0;
}
相关推荐
- 再说圆的面积-蒙特卡洛(蒙特卡洛方法求圆周率的matlab程序)
-
在微积分-圆的面积和周长(1)介绍微积分方法求解圆的面积,本文使用蒙特卡洛方法求解圆面积。...
- python创建分类器小结(pytorch分类数据集创建)
-
简介:分类是指利用数据的特性将其分成若干类型的过程。监督学习分类器就是用带标记的训练数据建立一个模型,然后对未知数据进行分类。...
- matplotlib——绘制散点图(matplotlib散点图颜色和图例)
-
绘制散点图不同条件(维度)之间的内在关联关系观察数据的离散聚合程度...
- python实现实时绘制数据(python如何绘制)
-
方法一importmatplotlib.pyplotaspltimportnumpyasnpimporttimefrommathimport*plt.ion()#...
- 简单学Python——matplotlib库3——绘制散点图
-
前面我们学习了用matplotlib绘制折线图,今天我们学习绘制散点图。其实简单的散点图与折线图的语法基本相同,只是作图函数由plot()变成了scatter()。下面就绘制一个散点图:import...
- 数据分析-相关性分析可视化(相关性分析数据处理)
-
前面介绍了相关性分析的原理、流程和常用的皮尔逊相关系数和斯皮尔曼相关系数,具体可以参考...
- 免费Python机器学习课程一:线性回归算法
-
学习线性回归的概念并从头开始在python中开发完整的线性回归算法最基本的机器学习算法必须是具有单个变量的线性回归算法。如今,可用的高级机器学习算法,库和技术如此之多,以至于线性回归似乎并不重要。但是...
- 用Python进行机器学习(2)之逻辑回归
-
前面介绍了线性回归,本次介绍的是逻辑回归。逻辑回归虽然名字里面带有“回归”两个字,但是它是一种分类算法,通常用于解决二分类问题,比如某个邮件是否是广告邮件,比如某个评价是否为正向的评价。逻辑回归也可以...
- 【Python机器学习系列】拟合和回归傻傻分不清?一文带你彻底搞懂
-
一、拟合和回归的区别拟合...
- 推荐2个十分好用的pandas数据探索分析神器
-
作者:俊欣来源:关于数据分析与可视化...
- 向量数据库:解锁大模型记忆的关键!选型指南+实战案例全解析
-
本文较长,建议点赞收藏,以免遗失。更多AI大模型应用开发学习视频及资料,尽在...
- 用Python进行机器学习(11)-主成分分析PCA
-
我们在机器学习中有时候需要处理很多个参数,但是这些参数有时候彼此之间是有着各种关系的,这个时候我们就会想:是否可以找到一种方式来降低参数的个数呢?这就是今天我们要介绍的主成分分析,英文是Princip...
- 神经网络基础深度解析:从感知机到反向传播
-
本文较长,建议点赞收藏,以免遗失。更多AI大模型应用开发学习视频及资料,尽在...
- Python实现基于机器学习的RFM模型
-
CDA数据分析师出品作者:CDALevelⅠ持证人岗位:数据分析师行业:大数据...
你 发表评论:
欢迎- 一周热门
- 最近发表
- 标签列表
-
- idea eval reset (50)
- vue dispatch (70)
- update canceled (42)
- order by asc (53)
- spring gateway (67)
- 简单代码编程 贪吃蛇 (40)
- transforms.resize (33)
- redisson trylock (35)
- 卸载node (35)
- np.reshape (33)
- torch.arange (34)
- npm 源 (35)
- vue3 deep (35)
- win10 ssh (35)
- vue foreach (34)
- idea设置编码为utf8 (35)
- vue 数组添加元素 (34)
- std find (34)
- tablefield注解用途 (35)
- python str转json (34)
- java websocket客户端 (34)
- tensor.view (34)
- java jackson (34)
- vmware17pro最新密钥 (34)
- mysql单表最大数据量 (35)