std::string

std::string是C++标准库中的一个基本类模板,专门用于处理字符串。它提供了一个可变长度的字符序列,以及一系列用于字符串操作的方法。std::string是值类型,这意味着当它作为函数参数传递或赋值时,整个字符串数据会被复制。

std::string的特性:

  • 可变长度:std::string可以动态地调整大小以存储不同长度的字符串
  • 随机访问:std::string可以通过索引随机访问字符
  • 自动内存管理:无需手动管理内存,std::string会自动分配和释放内存
  • 模板类:std::string是一个模板类,但通常用于char类型的字符串

std::string对象通常包含了一个指向堆上分配的内存的指针,用于存储较长的字符串。较短的字符串可能会直接存在对象本身的内部缓冲区,有些实现还会使用一个独立的缓冲区来存储字符串内容。

std::string提供了一系列成员函数来操作对象:

  • 构造函数

    • std::string():默认构造一个空字符串

    • std::string(const char* str):从C风格字符串构造

    • std::string(const std::string& str):拷贝构造函数,深拷贝

      std::string str = "abc12345";  // 创建一个字符串,并进行初始化
      std::cout << str << std::endl;  // abc12345std::string new_str1(str);  // 拷贝构造,深拷贝
      std::cout << str << std::endl;  // abc12345
      std::cout << new_str1 << std::endl;  // abc12345std::string new_str2(std::move(str));  // 移动构造
      std::cout << str.size() << std::endl;  // 0
      std::cout << new_str2 << std::endl;  // abc12345
      
      std::string str = "abc12345";  // 创建一个字符串,并进行初始化
      const char* cstr = str.c_str();  // c_str()返回指向字符串第一个字符的指针
      std::cout << *cstr << std::endl;  // a
      std::cout << cstr << std::endl;  // abc12345c_str()返回的指针指向的是一个只读的C风格字符串,这意味着不能通过这个指针来修改std::string对象中字符串的内容。
      
  • 赋值操作

    • 赋值运行符 =:将一个字符串的内容复制给另一个字符串

    • swap(std::string& other):交换两个字符串的内容

      std::string str = "abc12345";  // 创建一个字符串,并进行初始化std::string new_str = str;  // 赋值操作,深拷贝
      std::cout << str << std::endl;  // abc12345
      std::cout << new_str << std::endl;  // abc12345std::string swap_str = "678";
      str.swap(swap_str);  // 交换两个字符串
      std::cout << str << std::endl;  // 678
      std::cout << swap_str << std::endl;  // abc12345
      
  • 连接字符串

    • operator +:连接两个字符串

    • operator +=:将另一个字符串连接到当前字符串

      std::string str = "abc12345";  // 创建一个字符串,并进行初始化
      std::string new_str = "678";std::string conn_str = str + new_str;  // 连接字符串
      std::cout << conn_str << std::endl;  // abc12345678
      
  • 访问字符

    • operator[]:通过索引访问字符串中的字符

    • at(size_type n):通过索引访问字符串中的字符,带边界检查

    • front():返回字符串中的第一个字符

    • back():返回字符串中的最后一个字符

      std::string str = "abc12345";  // 创建一个字符串,并进行初始化
      std::cout << str[1] << std::endl;  // 访问索引为1的字符,b
      std::cout << str.at(7) << std::endl;  // 访问索引为7的字符,5
      std::cout << str.front() << std::endl;  // 返回第一个字符,a
      std::cout << str.back() << std::endl;  // 返回最后一个字符,5
      
  • 查找和替换

    • find():在字符串中查找子字符串或字符

    • replace():替换字符串中的部分内容

      std::string str = "abc12345cba";  // 创建一个字符串,并进行初始化
      std::cout << str.find("b") << std::endl;  // 查找字符串中从左到右的第一个字符b,并返回其索引,1
      std::cout << str.rfind("b") << std::endl;  // 查找字符串中从右到左的第一个字符b,并返回其索引,9
      std::cout << str.find("abc") << std::endl;  // 查找字符串中的子字符串,返回其开头索引,0
      std::cout << str.find("abcd") << std::endl;  // 若查找不到子字符串或字符,则返回一个随机数,18446744073709551615str.replace(3, 5, "321");  // 从索引为3的字符开始,将5个字符换成321
      std::cout << str << std::endl;  // abc321cba
      
  • 修改字符串

    • push_back(char ch):在字符串末尾添加一个字符

    • pop_back():移除字符串末尾的字符

    • append(std::string& other):在字符串末尾添加一个字符串

    • erase():删除字符串中的指定位置或指定范围的字符

    • assign(std::string& other):用新的字符串替换原有内容

    • insert():在指定位置插入字符或字符串

    • resize():修改字符串的大小

    • clear():清空字符串

      std::string str = "abc12345";  // 创建一个字符串,并进行初始化str.push_back('A');  // 字符串末尾添加一个字符
      std::cout << str << std::endl;  // abc12345Astr.pop_back();  // 移除字符串末尾的字符
      std::cout << str << std::endl;  // abc12345str.append("678A");  // 字符串末尾添加字符串
      std::cout << str << std::endl;  // abc12345678Astr.erase(5);  // 删除字符串中索引为5及以后的字符
      std::cout << str << std::endl;  // abc12
      str.erase(1, 3);  // 删除字符串中索引从1开始的3个字符
      std::cout << str << std::endl;  // a2str.assign("678");  // 用新的字符串替换掉原来的字符串
      std::cout << str << std::endl;  // 678str.clear();  // 清空字符串
      std::cout << str.size() << std::endl;  // 0
      
  • 子字符串

    • substr():提取子字符串

      std::string str = "abc12345";  // 创建一个字符串,并进行初始化
      std::string sub_str = str.substr(2, 4);  // 提取从索引2开始共4个字符的子字符串
      std::cout << sub_str << std::endl;  // c123
      
  • 容量

    • length():返回字符串的长度

    • size():返回字符串中的字符数量,也就是字符串长度

    • capacity():返回字符串的容量

    • reserve():更改容量

      std::string str = "abc12345";  // 创建一个字符串,并进行初始化
      std::cout << str.length() << std::endl;  // 8
      std::cout << str.size() << std::endl;  // 8
      std::cout << str.capacity() << std::endl;  // 15str.push_back('6');
      std::cout << str.capacity() << std::endl;  // 15str.reserve(20);  // 更改容量,容量会变得更大,但不一定是给出的值,因为容量的变化是按照指数或线性规律来的
      std::cout << str.capacity() << std::endl;  // 31长度表示字符串当前实际包含的字符数,而容量表示分配给字符数组的内存空间大小。当字符串的长度超过容量时,std::string会重新分配更大的内存空间,并将原有的字符复制到新的内存位置。当std::string对象的生命周期结束时,它会自动释放所分配的内存,不需要手动调用delete或free()释放字符串的内存,因为std::string类会在对象销毁时自动调用相应的析构函数来释放内存。与C语言中的字符串类似,std::string的底层实现也会在字符数组的末尾添加一个空终止字符(‘\0’),以表示字符串的结束。这样可以使得std::string类的接口与标准C字符串函数兼容,但是std::string的size()length()不会统计('\0')。
      
  • 迭代器

    • begin():返回指向第一个字符的迭代器

    • end():返回指向尾后一位的迭代器

      std::string str = "abc12345";  // 创建一个字符串,并进行初始化
      for (auto it = str.begin(); it != str.end(); ++it) {std::cout << *it << std::endl;  // a b c 1 2 3 4 5
      }
      for (auto value : str) {std::cout << value << std::endl;  // a b c 1 2 3 4 5
      }
      
  • 其他成员函数

    • data():返回指向字符串第一个字符的指针
    • c_str():返回指向字符串第一个字符的指针
    • empty():检查字符串是否为空

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/880993.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Git 下载及安装超详教程(2024)

操作环境&#xff1a;Win 10、全程联网 一、什么是Git&#xff1f; Git 是一个开源的分布式版本控制系统&#xff0c;由 Linus Torvalds 创立&#xff0c;用于有效、高速地处理从小到大的项目版本管理。Git 是目前世界上最流行的版本控制系统&#xff0c;被广泛用于软件开发中…

ECCV 2024 | 融合跨模态先验与扩散模型,快手处理大模型让视频画面更清晰!

计算机视觉领域顶级会议 European Conference on Computer Vision&#xff08;ECCV 2024&#xff09;将于9月29日至10月4日在意大利米兰召开&#xff0c;快手音视频技术部联合清华大学所发表的题为《XPSR: Cross-modal Priors for Diffusion-based Image Super-Resolution》——…

安防监控/视频系统EasyCVR视频汇聚平台如何过滤134段的告警通道?

视频汇聚/集中存储EasyCVR安防监控视频系统采用先进的网络传输技术&#xff0c;支持高清视频的接入和传输&#xff0c;能够满足大规模、高并发的远程监控需求。平台支持国标GB/T 28181协议、部标JT808、GA/T 1400协议、RTMP、RTSP/Onvif协议、海康Ehome、海康SDK、大华SDK、华为…

基于Zynq SDIO WiFi移植三(支持2.4/5G)

应用问题-WIFI作为AP-hostapd多次连接 设备作为WIFI热点时&#xff0c;连接出现了下述问题&#xff1a; 1 手机连接需要三次&#xff0c;三次都需要输入密码&#xff1b; 2 平板连接需要三次&#xff0c;三次都需要输入密码&#xff1b; 3 电脑连接需要一次&#xff0c;无感…

计算机视觉——图像修复综述篇

目录 1. Deterministic Image Inpainting 判别器图像修复 1.1. sigle-shot framework (1) Generators (2) training objects / Loss Functions 1.2. two-stage framework 2. Stochastic Image Inpainting 随机图像修复 2.1. VAE-based methods 2.2. GAN-based methods …

YOLOv11改进 | Conv篇 | YOLOv11引入SKConv

1. SKConv介绍 1.1 摘要:在标准卷积神经网络(CNN)中,每层中阿尔蒂神经元的感受野被设计为共享相同的大小。在神经科学界众所周知,视觉皮层神经元的感受野大小受到刺激的调制,这在构建CNN时很少考虑。我们在CNN中提出了一种动态选择机制,允许每个神经元根据输入信息的多…

[深度学习][python]yolov11+deepsort+pyqt5实现目标追踪

【算法介绍】 YOLOv11、DeepSORT和PyQt5的组合为实现高效目标追踪提供了一个强大的解决方案。 YOLOv11是YOLO系列的最新版本&#xff0c;它在保持高检测速度的同时&#xff0c;通过改进网络结构、优化损失函数等方式&#xff0c;提高了检测精度&#xff0c;能够同时处理多个尺…

【嵌入式软件-数据结构与算法】01-数据结构

摘录于老师的教学课程~~(*๓╰╯๓)~~内含链表、队列、栈、循环队列等详细介绍~~ 基础知识系列 有空再继续更~~~ 目录 【链表】 一、单链表 1、存储结构&#xff1a;带头结点的单链表 2、单链表结点类型的定义 3、创建单链表 1&#xff09;头插法 2&#xff09;尾插法 …

Python办公自动化之Word

在现代办公环境中&#xff0c;自动化无疑是提升工作效率的关键。特别是处理文档的工作&#xff0c;很多人可能花费大量时间在重复性任务上。那么&#xff0c;有没有一种方法可以让我们用 Python 来自动化 Word 文档的操作呢&#xff1f;今天&#xff0c;我们来聊聊如何用 Pytho…

k8s-集群部署1

k8s-集群部署1 一、基础环境准备二、docker环境准备三、k8s集群部署1.kubeadm创建集群2.使用kubeadm引导集群 总结 一、基础环境准备 首先&#xff0c;需要准备三个服务器实例&#xff0c;这里我使用了阿里云创建了三个实例&#xff0c;如果不想花钱&#xff0c;也可以在VM上创…

windows配置C++编译环境和VScode C++配置(保姆级教程)

1.安装MinGW-w64 MinGW-w64是一个开源的编译器套件&#xff0c;适用于Windows平台&#xff0c;支持32位和64位应用程序的开发。它包含了GCC编译器、GDB调试器以及其他必要的工具&#xff0c;是C开发者在Windows环境下进行开发的重要工具。 我找到了一个下载比较快的链接&#…

初识Linux · 自主Shell编写

目录 前言&#xff1a; 1 命令行解释器部分 2 获取用户命令行参数 3 命令行参数进行分割 4 执行命令 5 判断命令是否为内建命令 前言&#xff1a; 本文介绍是自主Shell编写&#xff0c;对于shell&#xff0c;即外壳解释程序&#xff0c;我们目前接触到的命令行解释器&am…

技术成神之路:设计模式(十八)适配器模式

介绍 适配器模式&#xff08;Adapter Pattern&#xff09;是一种结构型设计模式&#xff0c;它允许接口不兼容的类可以协同工作&#xff0c;通过将一个类的接口转换成客户端所期望的另一个接口&#xff0c;使得原本由于接口不兼容而不能一起工作的类可以一起工作。 1.定义 适配…

基础算法--枚举

枚举算法是一种简单而有效的算法&#xff0c;它通过枚举所有可能的情况来解决问题。它通常用于解决问题规模比较小的问题&#xff0c;因为它的时间复杂度很高&#xff0c;随着问题的规模增加&#xff0c;算法的效率会急剧下降。 枚举算法的基本思路是通过循环遍历所有可能的情…

CSS实现服务卡片

CSS实现服务卡片 效果展示 CSS 知识点 回顾整体CSS知识点灵活运用CSS知识点 页面整体布局 <div class"container"><div class"card"><div class"box"><div class"icon"><ion-icon name"color-pal…

记录一次病毒启动脚本

在第一次下载软件时&#xff0c;目录中配了一个使用说明&#xff0c;说是需要通过start.bat 这个文件来启动程序&#xff0c;而这个 start.bat 就是始作俑者&#xff1a; 病毒作者比较狡猾&#xff0c;其中start.bat 用记事本打开是乱码&#xff0c;但是可以通过将这个批处理…

OpenMV与STM32通信全面指南

目录 引言 一、OpenMV和STM32简介 1.1 OpenMV简介 1.2 STM32简介 二、通信协议概述 三、硬件连接 3.1 硬件准备 3.2 引脚连接 四、软件环境搭建 4.1 OpenMV IDE安装 4.2 STM32开发环境 五、UART通信实现 5.1 OpenMV端编程 5.2 STM32端编程 六、SPI通信实现 6.1 …

查缺补漏----I/O中断处理过程

中断优先级包括响应优先级和处理优先级&#xff0c;响应优先级由硬件线路或查询程序的查询顺序决定&#xff0c;不可动态改变。处理优先级可利用中断屏蔽技术动态调整&#xff0c;以实现多重中断。下面来看他们如何运用在中断处理过程中&#xff1a; 中断控制器位于CPU和外设之…

动态规划最长上升子序列问题讲解和【题解】——最长上升子序列

动态规划最长上升子序列讲解和题解——最长上升子序列 最长上升子序列问题讲解1.概念解析2.举例了解3.示例程序 最长上升子序列题目描述输入格式输出格式输入输出样例输入 #1输出 #1 提示思路解析 最长上升子序列问题讲解 1.概念解析 最长上升子序列 &#xff08; L o n g e s…

微服务sentinel解析部署使用全流程

sentinel源码地址&#xff1a; 介绍 alibaba/Sentinel Wiki GitHub sentinel官方文档&#xff1a; https://sentinelguard.io/zh-cn/docs/introduction.html Sprong Cloud alibaba Sentinel文档【小例子】 : Sentinel alibaba/spring-cloud-alibaba Wiki GitHub 目录 1、…