C++中string笔记杂谈

string 类库中的size_type是一种怎样的自定义类型

在 C++ 的 string 类库中,size_type 是一种无符号整数类型,用于表示字符串的大小(长度)。

它被定义为能够容纳字符串可能的最大长度的无符号整数类型。

比如说,如果一个字符串可能非常长,使用普通的 int 可能无法表示其长度,这时就会使用 size_type 来确保有足够的范围来准确表示字符串的长度。

举个例子,如果要遍历一个字符串 std::string str = "Hello World"; ,可以这样写:

for (std::string::size_type i = 0; i < str.size(); ++i) {
    // 对每个字符进行操作
}

 这样能保证在处理不同长度的字符串时,不会出现长度表示范围不足的问题。

这样设计的原因

string 类中使用 size_type 这样的自定义类型来表示字符串的大小主要有以下几个原因:

  1. 可移植性:不同的平台上,整数类型的大小可能会有所不同。使用自定义的 size_type 可以确保在各种平台上,string 的大小表示都能有一致的行为和足够的范围。

  2. 明确语义:使用 size_type 能更清晰地表明这个类型专门用于表示字符串的大小,增加了代码的自解释性。

  3. 避免错误:如果直接使用 int 或其他固定的整数类型,可能会在处理特别长的字符串时出现溢出等错误。而 size_type 通常被设计为能够适应字符串可能达到的最大长度。

  4. 与标准库的一致性:整个标准库在很多容器和数据结构中都采用了类似的设计,使用自定义的类型来表示特定的度量,这有助于保持代码风格的统一和可理解性。

string对象与字符串字面值

在 C++ 中,将 string 对象与字符串字面值常量相加时,需要确保字符串字面值常量被明确转换为 string 类型。

可以使用 + 运算符来实现相加,例如:

std::string str = "Hello ";
std::string result = str + "World"; 

在 C++ 中,不能直接使用 + 运算符把两个 const char 数组(也就是字符串字面值)相加。

std::string s2 = "world";
std::string s4 = "hello" + "," + s2;

其中字面值字符串“hello”和“,”是不能之间相加的,需要显示的进行类型转换string("hello")

 string对象与字符串字面值相加时产生的临时对象

如:

string s1 = "hello";
string s3 = s1 + "," + "world";

与下面的语句是等价的:

string s1 = "hello";
string tmp = s1 + ",";
string s3 = tmp + "world";

tmp就是产生的临时对象。

在执行表达式计算过程中,会创建这个临时对象来存储中间结果。通常,编译器会在需要的时候分配内存来存储这个临时对象,并且在表达式的计算完成后,如果没有其他引用指向它,它会在适当的时候被释放。

string类的输入运算符和getline()函数是如何处理空白字符的

 

在 C++ 的 string 类中,输入运算符 >> 和 getline() 函数在处理空白字符时有不同的行为。

输入运算符 >> 会自动忽略输入前面的空白字符(如空格、制表符、换行符等),并且在遇到空白字符时会停止读取,将之前读取的非空白字符部分作为一个字符串存入目标 string 对象中。

例如,如果输入是 hello world ,使用 std::cin >> str; ,那么 str 只会被赋值为 hello 。

而 getline() 函数则会读取包括空白字符在内的一整行输入,直到遇到换行符为止。

例如,如果输入是 hello world ,使用 std::getline(std::cin, str); ,那么 str 会被赋值为 hello world 。

范围for语句

范围 for 语句是 C++11 引入的一种更简洁的循环结构,用于遍历一个序列(如数组、vector 、string 等)中的每个元素。

其一般形式为:

for (declaration : expression)
    statement

在处理 string 的每个字符时,范围 for 语句非常有用。它可以让您无需关心索引的操作,就能直接遍历字符串中的每个字符。

std::string str = "Hello";
for (char c : str) 
{
    std::cout << c << " ";
}

 

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

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

vim练级攻略(精简版)

vim推荐配置: curl -sLf https://gitee.com/HGtz2222/VimForCpp/raw/master/install.sh -o ./install.sh && bash ./install.sh 0. 规定 Ctrl-λ 等价于 <C-λ> :command 等价于 :command <回车> n 等价于 数字 blank字符 等价于 空格&#xff0c;tab&am…

VSCode 的部署

一、VSCode部署 (1)、简介 vsCode 全称 Visual Studio Code&#xff0c;是微软出的一款轻量级代码编辑器&#xff0c;免费、开源而且功能强大。它支持几乎所有主流的程序语言的语法高亮、智能代码补全、自定义热键、括号匹配、代码片段、代码对比Diff、版本管理GIT等特性&…

Nginx在Linux中的最小化安装方式

1. 安装依赖 需要安装的东西&#xff1a; wget​&#xff0c;方便我们下载Nginx的包。如果是在Windows下载&#xff0c;然后使用SFTP上传到服务器中&#xff0c;那么可以不安装这个软件包。gcc g​&#xff0c;Nginx是使用C/C开发的服务器&#xff0c;等一下安装会用到其中的…

如何在vue中渲染markdown内容?

文章目录 引言什么是 markdown-it&#xff1f;安装 markdown-it基本用法样式失效&#xff1f;解决方法 高级配置语法高亮 效果展示 引言 在现代 Web 开发中&#xff0c;Markdown 作为一种轻量级的标记语言&#xff0c;广泛用于文档编写、内容管理以及富文本编辑器中。markdown…

Android 高版本如何获取App安装列表?

有个需求需要获取App内的安装列表,但是现在在高版本Android中,只能获取到一部分App效果,我获取的代码如下: val calendar Calendar.getInstance()val packageManager context.packageManagerval usageStatsManager context.getSystemService(Context.USAGE_STATS_SERVICE) …

第 5 场 算法季度赛

题目&#xff1a; 5.精准难度【算法赛】 - 蓝桥云课 问题描述 小蓝&#xff0c;蓝桥杯命题组的核心人物。今年的他出题灵感爆发&#xff0c;一口气出了 N 道题目&#xff0c;难度系数分别为 A1​,A2​,…,AN​。 只是&#xff0c;这些题目的难度参差不齐&#xff0c;让组委…

对话 TDengine 解决方案中心总经理陈肃:构建技术与市场的桥梁

TD 小T导读 他是大数据领域的杰出专家&#xff0c;拥有超过十项一作发明专利&#xff0c;是中国通信行业标准《大数据 消息中间件技术要求与测试方法》的重要编写者&#xff0c;并凭借数据中间件领域的突出成就荣获 2019 年“CJK OSS Award”。他是腾讯云 TVP 专家和 TGO 鲲鹏会…

rabbitmq安装延迟队列

在RabbitMQ中&#xff0c;延迟队列是一种特殊的队列类型。当消息被发送到此类队列后&#xff0c;不会立即投递给消费者&#xff0c;而是会等待预设的一段时间&#xff0c;待延迟期满后才进行投递。这种队列在多种场景下都极具价值&#xff0c;比如可用于处理需要在特定时间触发…

GitLab集成Jira

GitLab与Jira集成的两种方式 GitLab 提供了两种 Jira 集成&#xff0c;即Jira议题集成和Jira开发面板集成&#xff0c;可以配置一个或者两个都配置。 具体集成步骤可以参考官方文档Jira 议题集成&#xff08;极狐GitLab文档&#xff09;和Jira 开发面板集成&#xff08;极狐G…

【正则表达式】从0开始学习正则表达式

正则表达式&#xff08;英语&#xff1a;Regular Expression&#xff0c;在代码中常简写为regex、regexp或RE&#xff09; 一、推荐学习网站 正则表达式 – 语法 | 菜鸟教程 正则表达式30分钟入门教程 | 菜鸟教程 编程胶囊-打造学习编程的最好系统 二、必知必记 2.1 元字符…

【docker踩坑记录】

docker踩坑记录 踩坑记录(持续更新中.......)docker images 权限问题 踩坑记录(持续更新中…) docker images 权限问题 permission denied while trying to connect to the Docker daemon socket at unix:///var/run/docker.sock: Head "http://%2Fvar%2Frun%2Fdocker.s…

HackMyVM-Klim靶机的测试报告

目录 一、测试环境 1、系统环境 2、使用工具/软件 二、测试目的 三、操作过程 1、信息搜集 2、Getshell 3、提权 CVE-2008-0166 四、结论 一、测试环境 1、系统环境 渗透机&#xff1a;kali2021.1(192.168.159.127) 靶 机&#xff1a;debian(192.168.159.27) 注意事…

Hexo + NexT + Github搭建个人博客

文章目录 一、 安装二、配置相关项NexT config更新主题主题样式本地实时预览常用命令 三、主题设置1.侧边栏2.页脚3.帖子发布字数统计 4.自定义自定义页面Hexo 的默认页面自定义 404 页自定义样式 5.杂项搜索服务 四、第三方插件NexT 自带插件评论系统阅读和访问人数统计 五、部…

CamemBERT:一款出色的法语语言模型

摘要 预训练语言模型在自然语言处理中已无处不在。尽管这些模型取得了成功&#xff0c;但大多数可用模型要么是在英语数据上训练的&#xff0c;要么是在多种语言数据拼接的基础上训练的。这使得这些模型在除英语以外的所有语言中的实际应用非常有限。本文探讨了为其他语言训练…

基于PyQt - 6的医疗多模态大模型医疗研究系统中的创新构建与应用(上 .文章部分)

一、引言 1.1 研究背景与意义 在当今数智化时代,医疗行业正经历着深刻的变革,对智能化、高效化的需求日益迫切。传统的医疗模式在面对海量的医疗数据、复杂的诊断流程以及个性化的治疗需求时,逐渐显露出局限性。随着人工智能技术的飞速发展,多模态大模型作为一种前沿技术…

(一)afsim第三方库编译

注意&#xff1a;防止奇怪的问题&#xff0c;源码编译的路径最好不要有中文&#xff0c;请先检查各文件夹名 AFSIM版本 Version&#xff1a; 2.9 Plugin API Version&#xff1a; 11 软件环境 操作系统&#xff1a; Kylin V10 SP1 项目构建工具: cmake-3.26.0-linux-aarch6…

【NextJS】PostgreSQL 遇上 Prisma ORM

NextJS 数据库 之 遇上Prisma ORM 前言一、环境要求二、概念介绍1、Prisma Schema Language&#xff08;PSL&#xff09; 结构描述语言1.1 概念1.2 组成1.2.1 Data Source 数据源1.2.2 Generators 生成器1.2.3 Data Model Definition 数据模型定义字段(数据)类型和约束关系&…

细说STM32F407单片机电源低功耗SleepMode模式及应用示例

目录 一、STM32F4的低功耗模式 1、睡眠(Sleep)模式 2、停止(Stop)模式 3、待机(Standby)模式 二、睡眠模式 1、进入睡眠模式 2、睡眠模式的状态 3、退出睡眠模式 4、SysTick的影响 三、应用示例 1、工程配置 &#xff08;1&#xff09; 时钟、DEBUG、GPIO、CodeGen…

YOLOv11改进,YOLOv11检测头融合RepConv卷积,并添加小目标检测层(四头检测),适合目标检测、分割等任务

摘要 作者提出了一种简单而强大的卷积神经网络架构,其推理阶段采用与 VGG 类似的网络体结构,仅由一堆 3x3 卷积和 ReLU 组成,而训练阶段的模型具有多分支拓扑。这种训练阶段和推理阶段架构的解耦通过结构重参数化技术实现,因此我们将该模型命名为 RepVGG。 # 理论介绍 Re…

ScratchLLMStepByStep:训练自己的Tokenizer

1. 引言 分词器是每个大语言模型必不可少的组件&#xff0c;但每个大语言模型的分词器几乎都不相同。如果要训练自己的分词器&#xff0c;可以使用huggingface的tokenizers框架&#xff0c;tokenizers包含以下主要组件&#xff1a; Tokenizer: 分词器的核心组件&#xff0c;定…