自修C++Primer----3.2标准库类型string

2024-08-26 03:28

本文主要是介绍自修C++Primer----3.2标准库类型string,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

目录

1.String的相关操作

1.1拷贝初始化&&直接初始化

1.2显示创建临时对象

1.3读取string对象内容

1.4一次读取多个未知对象

1.5使用getline读取一整行内容

1.6size()的返回值size_type类型

1.7两个string对象比较

1.8string对象赋值

1.9两个string对象相加


1.String的相关操作

上面这个表里面介绍了初始化string的几种方式,例如这个默认的初始化,拷贝构造初始化,使用字面值进行初始化,连续字符进行初始化;

1.1拷贝初始化&&直接初始化

使用等号进行连接的,就是拷贝初始化,这个不是赋值,因为这个地方是使用一个已经存在的对象去初始化另外一个新创建的对象,如果这个s5本来就有内容,这个时候等号才叫做赋值;

下面的这个s6,s7都属于直接进行初始化,没有使用等号进行连接;

1.2显示创建临时对象

上面介绍的这个s7就是使用的10个c进行初始化的,这个是一个直接的初始化方式,我们也可以使用等号的方式进行拷贝初始化,只不过这个需要写成两个步骤,第一步就是使用直接初始化创建一个临时对象,然后使用这个临时对象拷贝构造s8这个对象,这个只是为了说明两个初始化的方式是可以进行转化的;

1.3读取string对象内容

我们以这个输入“     hello   world     ”内容作为案例进行下面的讨论;

第一个情况:按照下面的这个代码进行输入输出,这个时候只会输出hello,没有其他的内容,这个和cin的读取方式有关,对于这个s对象,我们可以略过这个输入里面的空白字符(hello前面的字符)从第一个有效字符进行读取,读取到两个单词之间的这个空白处就会停止这个过程,所以打印的结果里面只有hello ;

第二个情况:这个时候同样是上面的输入内容,我们进行两个cin,第一个cin返回值就是一个对象,这个对象作为结果再次进行输入,因此这个打印结果就是helloworld,因为这个时候s1里面就是读取的hello ,s2里面就是读取的world,输出的时候就会直接输出,没有空格;

1.4一次读取多个未知对象

下面这个就是用来进行测试的情况,只要我们一直输入,这个程序就会一直等待我们执行,按下enter键之后,这个就会进行cout的输出操作,我们输入的这个空格,在输出的时候都会被当做换行进行看待,遇到异常情况才会退出(我是直接使用的ctrl+z终止这个循环过程)这个cin读取的时候,不会像下面的这个getline一样去读取这个\n,cin读取的时候这个\n留在缓冲区里面,我们输入这个ctrl+z之后,这个循环不成立,因此就会退出循环;

1.5使用getline读取一整行内容

首先需要注意的就是使用这个getline需要包含对应的头文件string,否则就会报错,这个和上面区别就是这个会一次性读入一行内容,打印的时候是直接输出一行的内容,而且是在一行上面显示,上面的cin是在不同的行上面显示的;

实际上这个getline进行读取的时候,会读取到这个换行符,但是这个对象里面不会存在这个换行符,因此我们需要手动的添加,如果刚开始输入的时候就是换行符,这个读取的就是空值;

我们输出的时候,使用的这个endl实际上作用就是进行换行,因为这个getline读取的对象没有读取换行符,这个交给endl来完成,此外这个endl还会对于这个缓冲区进行刷新flush(在我的linux博客里面有这个证明缓冲区存在的过程),因此这个endl的作用就是换行+刷新缓冲区;

1.6size()的返回值size_type类型

这个我们只需要知道,这个size_type可以存下这个string对象,而且这个是一个无符号的类型;

当我们使用这个size()函数的时候,就不要使用int类型的变量,否则容易出错,下面就是一个典型的错误案例:

这个还不是直接跟这个size()函数的返回值相关,但是可以说明这个问题,就是这个整型提升的问题,发生了类型的转换,下面的这个是在string某一个位置插入数据;

当我们的这个end=0的时候,再次进行--就是-1,但是因为这个pos是一个size_t类型的,因此这个end就需要进行转换,-1转换之后就是一个很大的正数,导致这个循环停不下来,这个就是int和unsigned同时存在的时候出现的问题;

1.7两个string对象比较

这个比较的话,就是分情况的,如果两个的这个长度相同,每一个字符对应都是一样的,这个时候我们就可以去说这两个string对象是一样的;

如果长度不相同,这个时候不看长度,而是比较第一个相异字符ASCII大小,第一个相异字符大的这个string对象就更大;

1.8string对象赋值

我们上面介绍拷贝构造的时候也说明了这个问题,我们使用一个对象去初始化一个已经存在的对象,就是赋值,初始化一个新的对象,就是拷贝构造

1.9两个string对象相加

两个string的相加很简单,就是一个字符串的拼接;

我们重点是看一下这个string和字符串字面值的相加:

这个进行判断的标准就是每一个+符号的两边至少有一个是我们的string对象,s4是满足这个条件的,s5里面的+两侧都是字符串字面值,所以这个写法是不对的;

s6相当于这个s1+","是符合的,产生一个临时的string对象,这个对象再和world进行加法,这个是符合相加的原则的;

但是这个s7计算的时候从左向右进行运算,hello +","就是不符合要求的,因为不可以把字面值直接相加;

一个简单的练习:

如果是把这个输入的字符串拼接,很简单:

直接进行这个string的加法即可,随着我们的输入,这个str2就会不断的累加起来;

如果是使用空格把我们的输入的内容进行拼接,就需要注意一下:

这个时候如果我们直接加上这个 “  ”,这个时候开头就会出现空格,这个是因为我们的str2刚开始就是空的,所以前面有空格,这个时候我们需要加入这个if语句进行设置一下即可,这个if只会在第一次size=0的时候才会有作用;

这篇关于自修C++Primer----3.2标准库类型string的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1107418

相关文章

【C++ Primer Plus习题】13.4

大家好,这里是国中之林! ❥前些天发现了一个巨牛的人工智能学习网站,通俗易懂,风趣幽默,忍不住分享一下给大家。点击跳转到网站。有兴趣的可以点点进去看看← 问题: 解答: main.cpp #include <iostream>#include "port.h"int main() {Port p1;Port p2("Abc", "Bcc", 30);std::cout <<

C++包装器

包装器 在 C++ 中,“包装器”通常指的是一种设计模式或编程技巧,用于封装其他代码或对象,使其更易于使用、管理或扩展。包装器的概念在编程中非常普遍,可以用于函数、类、库等多个方面。下面是几个常见的 “包装器” 类型: 1. 函数包装器 函数包装器用于封装一个或多个函数,使其接口更统一或更便于调用。例如,std::function 是一个通用的函数包装器,它可以存储任意可调用对象(函数、函数

C++11第三弹:lambda表达式 | 新的类功能 | 模板的可变参数

🌈个人主页: 南桥几晴秋 🌈C++专栏: 南桥谈C++ 🌈C语言专栏: C语言学习系列 🌈Linux学习专栏: 南桥谈Linux 🌈数据结构学习专栏: 数据结构杂谈 🌈数据库学习专栏: 南桥谈MySQL 🌈Qt学习专栏: 南桥谈Qt 🌈菜鸡代码练习: 练习随想记录 🌈git学习: 南桥谈Git 🌈🌈🌈🌈🌈🌈🌈🌈🌈🌈🌈🌈🌈�

【C++】_list常用方法解析及模拟实现

相信自己的力量,只要对自己始终保持信心,尽自己最大努力去完成任何事,就算事情最终结果是失败了,努力了也不留遗憾。💓💓💓 目录   ✨说在前面 🍋知识点一:什么是list? •🌰1.list的定义 •🌰2.list的基本特性 •🌰3.常用接口介绍 🍋知识点二:list常用接口 •🌰1.默认成员函数 🔥构造函数(⭐) 🔥析构函数 •🌰2.list对象

06 C++Lambda表达式

lambda表达式的定义 没有显式模版形参的lambda表达式 [捕获] 前属性 (形参列表) 说明符 异常 后属性 尾随类型 约束 {函数体} 有显式模版形参的lambda表达式 [捕获] <模版形参> 模版约束 前属性 (形参列表) 说明符 异常 后属性 尾随类型 约束 {函数体} 含义 捕获:包含零个或者多个捕获符的逗号分隔列表 模板形参:用于泛型lambda提供个模板形参的名

零基础学习Redis(10) -- zset类型命令使用

zset是有序集合,内部除了存储元素外,还会存储一个score,存储在zset中的元素会按照score的大小升序排列,不同元素的score可以重复,score相同的元素会按照元素的字典序排列。 1. zset常用命令 1.1 zadd  zadd key [NX | XX] [GT | LT]   [CH] [INCR] score member [score member ...]

6.1.数据结构-c/c++堆详解下篇(堆排序,TopK问题)

上篇:6.1.数据结构-c/c++模拟实现堆上篇(向下,上调整算法,建堆,增删数据)-CSDN博客 本章重点 1.使用堆来完成堆排序 2.使用堆解决TopK问题 目录 一.堆排序 1.1 思路 1.2 代码 1.3 简单测试 二.TopK问题 2.1 思路(求最小): 2.2 C语言代码(手写堆) 2.3 C++代码(使用优先级队列 priority_queue)

【C++高阶】C++类型转换全攻略:深入理解并高效应用

📝个人主页🌹:Eternity._ ⏩收录专栏⏪:C++ “ 登神长阶 ” 🤡往期回顾🤡:C++ 智能指针 🌹🌹期待您的关注 🌹🌹 ❀C++的类型转换 📒1. C语言中的类型转换📚2. C++强制类型转换⛰️static_cast🌞reinterpret_cast⭐const_cast🍁dynamic_cast 📜3. C++强制类型转换的原因📝

C++——stack、queue的实现及deque的介绍

目录 1.stack与queue的实现 1.1stack的实现  1.2 queue的实现 2.重温vector、list、stack、queue的介绍 2.1 STL标准库中stack和queue的底层结构  3.deque的简单介绍 3.1为什么选择deque作为stack和queue的底层默认容器  3.2 STL中对stack与queue的模拟实现 ①stack模拟实现

自定义类型:结构体(续)

目录 一. 结构体的内存对齐 1.1 为什么存在内存对齐? 1.2 修改默认对齐数 二. 结构体传参 三. 结构体实现位段 一. 结构体的内存对齐 在前面的文章里我们已经讲过一部分的内存对齐的知识,并举出了两个例子,我们再举出两个例子继续说明: struct S3{double a;int b;char c;};int mian(){printf("%zd\n",s