百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 技术分类 > 正文

C++ string类的成员函数解析与使用

ztj100 2025-01-03 20:48 14 浏览 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;
}

相关推荐

如何将数据仓库迁移到阿里云 AnalyticDB for PostgreSQL

阿里云AnalyticDBforPostgreSQL(以下简称ADBPG,即原HybridDBforPostgreSQL)为基于PostgreSQL内核的MPP架构的实时数据仓库服务,可以...

Python数据分析:探索性分析

写在前面如果你忘记了前面的文章,可以看看加深印象:Python数据处理...

CSP-J/S冲奖第21天:插入排序

...

C++基础语法梳理:算法丨十大排序算法(二)

本期是C++基础语法分享的第十六节,今天给大家来梳理一下十大排序算法后五个!归并排序...

C 语言的标准库有哪些

C语言的标准库并不是一个单一的实体,而是由一系列头文件(headerfiles)组成的集合。每个头文件声明了一组相关的函数、宏、类型和常量。程序员通过在代码中使用#include<...

[深度学习] ncnn安装和调用基础教程

1介绍ncnn是腾讯开发的一个为手机端极致优化的高性能神经网络前向计算框架,无第三方依赖,跨平台,但是通常都需要protobuf和opencv。ncnn目前已在腾讯多款应用中使用,如QQ,Qzon...

用rust实现经典的冒泡排序和快速排序

1.假设待排序数组如下letmutarr=[5,3,8,4,2,7,1];...

ncnn+PPYOLOv2首次结合!全网最详细代码解读来了

编辑:好困LRS【新智元导读】今天给大家安利一个宝藏仓库miemiedetection,该仓库集合了PPYOLO、PPYOLOv2、PPYOLOE三个算法pytorch实现三合一,其中的PPYOL...

C++特性使用建议

1.引用参数使用引用替代指针且所有不变的引用参数必须加上const。在C语言中,如果函数需要修改变量的值,参数必须为指针,如...

Qt4/5升级到Qt6吐血经验总结V202308

00:直观总结增加了很多轮子,同时原有模块拆分的也更细致,估计为了方便拓展个管理。把一些过度封装的东西移除了(比如同样的功能有多个函数),保证了只有一个函数执行该功能。把一些Qt5中兼容Qt4的方法废...

到底什么是C++11新特性,请看下文

C++11是一个比较大的更新,引入了很多新特性,以下是对这些特性的详细解释,帮助您快速理解C++11的内容1.自动类型推导(auto和decltype)...

掌握C++11这些特性,代码简洁性、安全性和性能轻松跃升!

C++11(又称C++0x)是C++编程语言的一次重大更新,引入了许多新特性,显著提升了代码简洁性、安全性和性能。以下是主要特性的分类介绍及示例:一、核心语言特性1.自动类型推导(auto)编译器自...

经典算法——凸包算法

凸包算法(ConvexHull)一、概念与问题描述凸包是指在平面上给定一组点,找到包含这些点的最小面积或最小周长的凸多边形。这个多边形没有任何内凹部分,即从一个多边形内的任意一点画一条线到多边形边界...

一起学习c++11——c++11中的新增的容器

c++11新增的容器1:array当时的初衷是希望提供一个在栈上分配的,定长数组,而且可以使用stl中的模板算法。array的用法如下:#include<string>#includ...

C++ 编程中的一些最佳实践

1.遵循代码简洁原则尽量避免冗余代码,通过模块化设计、清晰的命名和良好的结构,让代码更易于阅读和维护...

取消回复欢迎 发表评论: