C++ string类的成员函数解析与使用
ztj100 2025-01-03 20:48 22 浏览 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;
}
相关推荐
- Jquery 详细用法
-
1、jQuery介绍(1)jQuery是什么?是一个js框架,其主要思想是利用jQuery提供的选择器查找要操作的节点,然后将找到的节点封装成一个jQuery对象。封装成jQuery对象的目的有...
- 前端开发79条知识点汇总
-
1.css禁用鼠标事件2.get/post的理解和他们之间的区别http超文本传输协议(HTTP)的设计目的是保证客户机与服务器之间的通信。HTTP的工作方式是客户机与服务器之间的请求-应答协议。...
- js基础面试题92-130道题目
-
92.说说你对作用域链的理解参考答案:作用域链的作用是保证执行环境里有权访问的变量和函数是有序的,作用域链的变量只能向上访问,变量访问到window对象即被终止,作用域链向下访问变量是不被允许的。...
- Web前端必备基础知识点,百万网友:牛逼
-
1、Web中的常见攻击方式1.SQL注入------常见的安全性问题。解决方案:前端页面需要校验用户的输入数据(限制用户输入的类型、范围、格式、长度),不能只靠后端去校验用户数据。一来可以提高后端处理...
- 事件——《JS高级程序设计》
-
一、事件流1.事件流描述的是从页面中接收事件的顺序2.事件冒泡(eventbubble):事件从开始时由最具体的元素(就是嵌套最深的那个节点)开始,逐级向上传播到较为不具体的节点(就是Docu...
- 前端开发中79条不可忽视的知识点汇总
-
过往一些不足的地方,通过博客,好好总结一下。1.css禁用鼠标事件...
- Chrome 开发工具之Network
-
经常会听到比如"为什么我的js代码没执行啊?","我明明发送了请求,为什么反应?","我这个网站怎么加载的这么慢?"这类的问题,那么问题既然存在,就需要去解决它,需要解决它,首先我们得找对导致问题的原...
- 轻量级 React.js 虚拟美化滚动条组件RScroll
-
前几天有给大家分享一个Vue自定义滚动条组件VScroll。今天再分享一个最新开发的ReactPC端模拟滚动条组件RScroll。...
- 一文解读JavaScript事件对象和表单对象
-
前言相信做网站对JavaScript再熟悉不过了,它是一门脚本语言,不同于Python的是,它是一门浏览器脚本语言,而Python则是服务器脚本语言,我们不光要会Python,还要会JavaScrip...
- Python函数参数黑科技:*args与**kwargs深度解析
-
90%的Python程序员不知道,可变参数设计竟能决定函数的灵活性和扩展性!掌握这些技巧,让你的函数适应任何场景!一、函数参数设计的三大进阶技巧...
- 深入理解Python3密码学:详解PyCrypto库加密、解密与数字签名
-
在现代计算领域,信息安全逐渐成为焦点话题。密码学,作为信息保护的关键技术之一,允许我们加密(保密)和解密(解密)数据。...
- 阿里Nacos惊爆安全漏洞,火速升级!(附修复建议)
-
前言好,我是threedr3am,我发现nacos最新版本1.4.1对于User-Agent绕过安全漏洞的serverIdentitykey-value修复机制,依然存在绕过问题,在nacos开启了...
- Python模块:zoneinfo时区支持详解
-
一、知识导图二、知识讲解(一)zoneinfo模块概述...
- Golang开发的一些注意事项(一)
-
1.channel关闭后读的问题当channel关闭之后再去读取它,虽然不会引发panic,但会直接得到零值,而且ok的值为false。packagemainimport"...
- Python鼠标与键盘自动化指南:从入门到进阶——键盘篇
-
`pynput`是一个用于控制和监控鼠标和键盘的Python库...
你 发表评论:
欢迎- 一周热门
- 最近发表
- 标签列表
-
- 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)