前言
本文主要介绍C++中STL基本知识和string类
7.1:初识STL
7.1.1:STL六大组件
算法要通过迭代器来访问容器中的数据
STL的六大组件:容器、算法、迭代器、仿函数、适配器、空间配置器
1.容器:各种数据结构,如vector、list、dequeue、set、map等用来存放数据
2.算法:各种常用的算法,如sort、find、copy、for_each等
3.迭代器:扮演了容器与算法之间的胶合剂
4.仿函数:行为类似函数,可以作为算法的某种策略
5.适配器:一种用来修饰容器或者仿函数或者、迭代器接口的东西
6.空间适配器:负责空间的配置和管理
7.1.2:vector存放内置数据类型
容器:vector 算法:for_each 迭代器:vector<int>::iterator
第一种遍历方式:通过while循环
第二种遍历方式:for循环
第三种遍历方式:使用STL中的for_each遍历算法
for_each的具体实现,记住,模板函数可以自动推导参数的类型,模板类不可以
7.1.3:vector容器存放自定义数据类型
当name和age是private类型时,使用友元全局函数进行访问
使用for循环进行访问,注意指针、结构体引用的问题(这里将name,和age改成public了,因为for里面不能访问private类型的成员属性)
7.1.4:容器嵌套容器
问题就是相当于如何通过指针访问二维数组里的数据?
使用for_each语句实现二维数组数据扫描,传入给printArr()函数的参数是*v,就是一个容器,所以要用一个容器来接收参数。容器套容器指针解出来是容器,容器解出来才是数据。
7.2:string相关
7.2.1:string的构造函数
7.2.2:string的赋值操作函数(=、assign)
直接使用等号或使用成员函数assign
7.2.3:string字符串拼接相关(+=、append)
使用+=运算符重载或者append成员函数
append(str, pos, n),pos表示str的第几个位置,n表示截取的长度
7.2.4:string的查找和替换(find、rfind、replace)
replace不同参数使用的一些情况
7.2.4:string字符串比较(compare)
7.2.5:string字符串的存取([]和at)
使用[]或者成员函数at都可以访问到字符串里的数据,和C语言中的字符指针操作是一样的
[]和at之间的区别
底层实现方面,[]操作符直接通过指针偏移来访问字符串中的单个字符,效率较高。而at()函数则会先进行边界检查,如果越界则抛出异常,效率较低。因此,在不需要进行边界检查的情况下,应该优先使用[]操作符。
7.2.6:字符串的插入和删除(insert、erase)
string类中的成员函数size()求出的字符串长度不包含字符串结束符’\0’,其功能和C语言中的strlen()是一样的
7.2.7:string中获取子串(substr)
substr(pos, n),pos代表开始截取的位置,n代表要截取的字符个数
Makefile中的subst
配合find()来获取qq邮箱中的qq号