1. string构造

string s;  定义一个新的空string对象,命名为s
string s(cp);  定义一个新的string对象,用cp所指向的(以空字符null结束的)C风格字符串初始化该对象
string s(s2);  定义一个新的string对象,并将它初始化为s2的副本string s(cp, n)    创建一个string对象,它被初始化为cp所指向数组的前n个元素的副本
string s(s2, pos2)  创建一个string对象,它被初始化为一个已存在的string对象s2中从下表pos2开始的字符的副本
string s(s2, pos2, len2)    创建一个string对象,它被初始化为s2中从下标pos2开始的len2个字符的副本。
  • 如果pos2 > s2.size(),则该操作未定义
  • 注意:n、len2和pos2都是unsigned值
char noNull[] = {'H', 'i'};//noNull未定义空字符结束
string s3(noNull);//此操作未定义

2. string insert assign erase

s.insert(p, t)   在迭代器p指向的元素之前插入一个值为t的新元素。返回指向新插入元素的迭代器
s.insert(p, n, t)   在迭代器p指向的元素之前插入n个值为t的新元素。返回void
s.insert(p, b, e) 在迭代器p指向的元素之前插入迭代器b和e标记范围内所有的元素。返回voids.insert(pos, n, c)  在下标为pos的元素之前插入n个字符c
s.insert(pos, s2)   在下标为pos的元素之前插入string对象s2的副本
s.insert(pos, s2, pos2, len)    在下标为pos的元素之前插入s2中从下标pos2开始的len个字符
s.insert(pos, cp, len)  在下标为pos的元素之前插入cp所指向数组的前len个字符
s.insert(pos, cp)   在下标为pos的元素之前插入cp所指向的以空字符结束的字符串副本s.assign(b, e)  用迭代器b和e标记范围内的元素替换s。对于string类型,该操作返回s;对于容器类型,则返回void
s.assign(n, t)  用值为t的n个副本替换s。对于string类型,该操作返回s;对于容器类型,则返回voids.assign(s2)  用s2的副本替换s
s.assign(s2, pos2, len) 用s2中从下标pos2开始的len个字符副本替换s
s.assign(cp, len)   用cp所指向数组的前len个字符副本替换s
s.assign(cp)    用cp所指向的以空字符结束的字符串副本替换ss.erase(pos, len) 删除从下标pos开始的len个字符
s.erase(p)  删除迭代器p指向的元素。返回一个迭代器,指向被删除元素后面的元素
s.erase(b, e)   删除迭代器b和e标记范围内的所有元素。

除非特殊声明,上述所有操作都返回s的引用

3. substr append replace

s.substr(pos, n) 返回一个string类型的字符串,它包含s中从下标pos开始的n个字符
s.substr(pos)   返回一个string类型的字符串,它包含从下标pos开始到s末尾的所有字符
s.substr()  返回s的副本s.append(args)    将args串接在s后面。返回s的引用
s.replace(pos, len, args)   删除s中从下标pos开始的len个字符,用args指定的字符代替之。返回s的应用,在这个版本中,args不能为b2, e2s.replace(b, e, args)    删除迭代器b和e标记的范围内所有的字符,用args替换之。返回s的引用
在这个版本中,args不能为s2, pos2, len2args取值
s2  string类型的字符串s2
s2, pos2, len2  字符串s2中从下标pos2开始的len2个字符
cp  指针cp指向的以空字符结束的数组
cp, len2    cp指向的以空字符结束的数组中前len2个字符
n, c    字符c的n个副本
b2, e2  迭代器b2和e2标记的范围内所有字符

4. find

s.find(args) 在s中查找args的第一次出现
s.rfind(args)   在s中查找args的最后一次出现
s.find_first_of(args)   在s中查找args的任意字符的第一次出现
s.find_last_of(args)    在s中查找args的任意字符的最后一次出现
s.find_first_not_of(args)   在s中查找第一个不属于args的字符
s.find_last_not_of(args)    在s中查找最后一个不属于args的字符args取值
c, pos  在s中,从下标pos标记的位置开始,查找字符c。pos的默认值为0
s2, pos 在s中,从下标pos标记的位置开始,查找string对象s2。pos的默认值为0
cp, pos 在s中,从下标pos标记的位置开始,查找指针cp所指向的C风格的以空字符结束的字符串。pos的默认值为0
cp, pos, n  在s中,从下标pos标记的位置开始,查找指针cp所指向数组的前n个字符。pos和n都没有默认值

5. compare操作

s.compare(s2)    比较s和s2
s.compare(pos1, n1, s2) 让s中从pos下标位置开始的n1个字符与s2作比较
s.compare(pos1, n1, s2, pos2, n2)   让s中从pos1下标位置开始的n1个字符与s2中从pos2下标位置开始的n2个字符作比较
s.compare(cp)   比较s和cp所指向的以空字符结束的字符串
s.compare(pos1, n1, cp) 让s中从pos1下标位置开始的n1个字符与cp所指向的字符串作比较
s.compare(pos1, n1, cp, n2) 让s中从pos1下标位置开始的n1个字符与cp所指向字符串的前n2个字符作比较

6. 数值转换

b是基数,默认是10

to_string(val);     //数值val的string表示
stoi (s, p, b); //int
stol (s, p, b);//long
stoul (s, p, b);//unsigned long
stoll (s, p, b);//long long
stoull (s, p, b);//unsigned long long
stod (s, p);//double
int i = 42;
string s = to_string(i);
double d = stod(s);

C++ Primer 5th笔记(9)chapter9 顺序容器 string相关推荐

  1. C++ Primer 5th笔记(9)chapter9 顺序容器 vector 容器的自增长 容器适配器

    1. vector 容器的自增长:当插入元素当存储空间不足时,vector 必须重新分配存储空间(比如将新空间大小增加为当前大小的2倍) 管理容量的成员函数 操作 定义 c.shrink_to_fit ...

  2. C++ Primer 5th笔记(9)chapter9 顺序容器 构造和赋值

    1. 容器对象的构造和赋值 1.1 构造 C c; C c; //默认构造函数 C c1(c2) C c1=c2; C c{a,b,c,-} C c={a,b,c,-} C c(b,e)//eg. l ...

  3. C++ Primer 5th笔记(chap 11)关联容器

    •map •multimap •set •multiset •set •unordered_map •unordered_set •unordered_multimap •unordered_mult ...

  4. C++primer十万字笔记 第九章 顺序容器

    顺序容器   容器就是特定类型对象的集合,顺序容器为程序员提供了控制元素存储和访问顺序的能力.这种顺序不依赖于元素的值,而是与元素加入容器时的位置相对应.标准库提供了三种容器类型. 顺序容器概述  标 ...

  5. C++ primer 5th笔记

    目录2022年11月25日 周五 阴 第一.二章:变量和基本类型 基本内置类型 unsigned float与double 'A'与"A" 布尔类型转换时 初始化与赋值 初始化 声 ...

  6. C++ Primer 5th笔记(9)chapter9 顺序容器

    1. 定义:元素按位置进行存储和访问.元素的排列次序与元素值无关,而是由元素添加到容器的次序决定的. 容器类型 定义 优点 缺点 string 可变大小数组 支持快速随机访问 在尾部之外的位置插入或删 ...

  7. C++ Primer 5th笔记(9)chapter9 顺序容器 get insert delete

    insert.delete需要解决两个问题: 在什么位置插入? 返回什么位置? 1. 访问对象 操作 定义 c.back(); 返回c中尾元素的引用, 若c为空, 函数行为未定义. c.front() ...

  8. C++ Primer 5th笔记(9)chapter9 顺序容器 forward_list

    1. 特殊的forward_list 单向链表的删除操作,真正删除的是某个元素后面的值(想想是为什么?) 操作 定义 lst.before_begin() 返回指向链表首元素之前不存在的元素的迭代器, ...

  9. C++ Primer 5th笔记(chap 11)关联容器---无序容器

    无序关联容器 unordered associative container •unordered_map •unordered_set •unordered_multimap •unordered_ ...

最新文章

  1. bootstrap 文件上传fileinput
  2. VOICE VOER IP(VoIP)理论(NP水平学的)
  3. mysql 临时表_第05问:MySQL 在处理临时结果集时,内部临时表会使用多少内存?...
  4. 神经网络加载数据 自建数据集 官方数据集 pytorch 显示数据集
  5. [转载] java中数组的反射的探究
  6. C# 对垒 VB.NET C#不行了?
  7. MYSQL的C 语言接口
  8. 大数据延长了乔布斯8年寿命?它其实还有更多潜力
  9. turbo c语言教程,turbo c语言教程(Turbo C language tutorial).doc
  10. python二维游戏编程 最强大脑游戏_看完《最强大脑》,我决定用Python做这个游戏...
  11. 面试题之MyBatis缓存
  12. cout输出中加入双引号
  13. win11如何切换输入法 win11快速切换输入法
  14. 1526: 小L的项链切割
  15. jdk,jre,jvm的包含关系
  16. 大佬帮忙看看加密ts流的.key文件内容,用的是什么加密算法
  17. 腾讯云硬盘挂载宝塔命令
  18. [转] 评 WOW技能天赋设计
  19. 设计模式(一)—单例模式(附Java代码)
  20. 单片机的四层电梯控制系统

热门文章

  1. java基础求三角形的面积
  2. python核心编程第二版pdf_Python Book电子书pdf版合集 Python核心高级编程第二版
  3. 医院无线网络系统设计
  4. 如何看懂发电机功率圆图
  5. Dataset:Big Mart Sales数据集的简介、下载、案例应用之详细攻略
  6. VM:如何向vmware虚拟机中传输文件(或者共享文件夹)之详细攻略(图文教程)
  7. DL之CNN优化技术:学习卷积神经网络CNN的优化、实践经验(练习调参)、从代码深刻认知CNN架构之练习技巧
  8. ML之预测:玩转2018世界杯—采用机器学习预测小组赛、十六比赛、四决赛、半决赛、决赛以及世界杯总冠军的各个队伍
  9. Lightgbm with Hyperopt
  10. Gym 101964 2018-2019 ACM-ICPC Southeastern European Regional Programming Contest (SEERC 2018)