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

/* 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个字符组成的字符串;
 *
 */
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 205,386评论 6 479
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 87,939评论 2 381
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 151,851评论 0 341
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,953评论 1 278
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,971评论 5 369
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,784评论 1 283
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 38,126评论 3 399
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,765评论 0 258
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 43,148评论 1 300
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,744评论 2 323
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,858评论 1 333
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,479评论 4 322
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 39,080评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,053评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,278评论 1 260
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 45,245评论 2 352
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,590评论 2 343

推荐阅读更多精彩内容