美文网首页
黑马C++视频笔记《STL之string》

黑马C++视频笔记《STL之string》

作者: 井底蛙蛙呱呱呱 | 来源:发表于2021-01-20 09:47 被阅读0次
    /* STL(Standard Template Library, 标准模板库)
     *  - STL从广义上而分为:容器(container),算法(algorithm),迭代器(iterator);
     *  - 容器和算法之间通过迭代器进行无缝连接;
     *  - STL几乎所有的代码都采用模板类或者模板函数。
     *
     *
     * STL六大组件:
     *  (1)容器:各种数据结构,如vector,list,deque,set,map等,用来储存数据;
     *      - 序列式容器:强调值的排序,序列式容器中的每个元素均有固定的位置;
     *      - 关联式容器:二叉树结构,各元素之间没有严格的物理上的顺序关系;
     *  (2)算法:各种常用的算法,如sort,find,copy,for_each;
     *      - 质变算法:运算过程中会更改区间内的元素的内容,如拷贝,删除,替换等;
     *      - 非质变算法:运算过程中不会更改区间内的元素内容,如查找、计数、遍历、寻找极值等;
     *  (3)迭代器:扮演容器和算法之间的胶合剂,每一种算法都有自己专属的迭代器;
     *      - 迭代器使用类似于指针,初学阶段可将迭代器理解为指针;
     *  (4)仿函数:行为类似函数,可作为算法的某种策略;
     *  (5)适配器(配接器):一种用来修饰容器或者仿函数或迭代器接口的东西;
     *  (6)空间适配器:负责空间的配置与管理。
     */
    
    
    /* string 基本概念
     * 本质:string是C++风格的字符串,而string本质上是一个类.
     *
     * string和char * 的区别:
     *  (1)char *是一个指针;
     *  (2)string是一个类,类内部封装了char*,管理这个字符串,是一个char*型的容器.
     *
     * 特点:
     *  - string类内部封装了很多成员方法,如查找find,拷贝copy,删除delete,替换replace,插入insert等;
     *  - string管理char*所分配的内存,不用担心复制越界和取值越界等,由类内部进行负责.
     *
     * string构造函数
     *  - `string();`, 创建一个空字符串,如:string a,创建字符变量a;
     *  - `string(const char* s);`, 使用c风格字符串s初始化,`const char * str = "hello world"; string s2(str)`;
     *  - `string(const string& s);`, 使用一个string对象初始化另一个string对象,相当于拷贝构造函数,`string s3(s2)`;
     *  - `string(int n, char c);`,使用n个字符c初始化,如 `string(3, 'a')` ==> 'aaa';
     *
     * string赋值操作
     *  - `string& operator=(const char* s);`,char*类型字符串赋值给当前字符串变量;
     *  - `string& operator=(const string &s);`, 吧字符串s赋值给当前字符串;
     *  - `string& operator=(char c);`,把字符赋值给当前的字符串;
     *  - `string& assign(const char *s);`,把字符串s赋值给当前的字符串;
     *  - `string& assign(const char *s, int n);`,把字符串s的前n个值赋值给当前字符串变量;
     *  - `string& assign(const string &s);`,把字符串s赋值给当前字符串变量,类似于拷贝构造;
     *  - `string& assign(int n, char c);`,用n个字符c赋值给当前字符串;
     *
     * string字符串拼接
     *  - `string& operator+=(const char* str);`, 重载+=操作符;
     *  - `string& operator+=(const char c);`,重载+=操作符;
     *  - `string& operator+=(const string& str);`,重载+=操作符;
     *  - `string& append(const char *s);`,添加s至末尾;
     *  - `string& append(const char *s, int n);`,把字符串s的前n个字符连接到当前字符串结尾;
     *  - `string& append(const string &s);`,同operator+=(cosnt string& str);
     *  - `string& append(const string &s, int pos, int n);`,字符串s中从pos开始的n个字符连接到字符串结尾;
     * - `string& push_back(const char c);`,添加单个字符。
     * 
     * 从上面也能看出:
     *   += 运算符:追加单个参数值。
     *   append 函数:允许追加多个参数值。
     *   push_back 函数:只能追加单个字符。
     
     *
     * string查找和替换
     *  查找:查找指定字符串是否存在;
     *  替换:在指定位置替换字符串;
     *  - `int find(const string& str, int pos=0) const;`,从pos位置开始查找字符串str第一次出现的位置;
     *  - `int find(const char* s, int pos=0) const;`,查找s第一次出现位置,从pos位置开始查找;
     *  - `int find(const char*s, int pos, int n) const;`,从pos位置开始查找s的前n个字符第一次出现的位置;
     *  - `int find(const char c, int pos=0) const;`,查找字符c第一次出现的位置;
     *  - `int rfind(const string& str, int pos=npos) const;`,从最后一个位置开始倒着查找str第一次出现的位置;
     *  - `int rfind(const char* s, int pos=npos) const;`,倒着查找s第一次出现位置,从pos位置开始查找;
     *  - `int find(const char*s, int pos, int n) const;`,倒着从pos位置开始查找s的前n个字符第一次出现的位置;
     *  - `int rfind(const char c, int pos=0) const;`,查找字符c最后一次出现的位置;
     *  - `string& replace(int pos, int n, const string& str);`,替换从pos开始的n个字符为字符串str;
     *  - `string& replace(int pos, int n, const char* s);`,替换从pos开始的n个字符为字符串s.
     *
     * 字符串比较
     * 字符串比较是按字符的ASCII码进行对比:
     *  (1) = 返回0;
     *  (2) > 返回1;
     *  (3) < 返回-1.
     * 函数原型:
     *  - `int compare(const string &s) const;`,与字符串s比较;
     *  - `int compare(const char *s) const;`,与字符串s比较.
     *
     * string中单字符存取方式有两种:
     *  - `char& operator[](int n);`, 通过[]方式存取字符,str[1]='a';
     *  - `char& at(int n);`,通过at方法获取字符;
     *
     * string插入与删除
     *  - `string& insert(int pos, const char* s);`,插入字符串;
     *  - `string& insert(int pos, const string& s);`, 插入字符串;
     *  - `string& insert(int pos, int n, char c);`,在指定位置插入n个字符c;
     *  - `string& erase(int pos, int n=npos);`, 从pos开始删除n个字符.
     *
     * string子串获取
     *  - `string substr(int pos=0, int n=npos) const;`,返回由pos开始的n个字符组成的字符串;
     *
     */
    

    相关文章

      网友评论

          本文标题:黑马C++视频笔记《STL之string》

          本文链接:https://www.haomeiwen.com/subject/qpghzktx.html