STL简介1. 什么是STLSTL(standard template libaray-标准模板库)是C标准库的重要组成部分不仅是一个可复用的组件库而且是一个包罗数据结构与算法的软件框架。2. STL的版本原始版本Alexander Stepanov、Meng Lee 在惠普实验室完成的原始版本本着开源精神他们声明允许任何人任意运用、拷贝、修改、传播、商业使用这些代码无需付费。唯一的条件就是也需要向原始版本一样做开源使用。HP 版本–所有STL实现版本的始祖。P. J. 版本由P. J. Plauger开发继承自HP版本被Windows Visual C采用不能公开或修改缺陷可读性比较低符号命名比较怪异。RW版本由Rouge Wage公司开发继承自HP版本被C Builder 采用不能公开或修改可读性一般。SGI版本由Silicon Graphics Computer SystemsInc公司开发继承自HP版 本。被GCC(Linux)采用可移植性好可公开、修改甚至贩卖从命名风格和编程 风格上看阅读性非常高。我们后面学习STL要阅读部分源代码主要参考的就是这个版本。3. STL的六大组件STL是一个不可多得的工具, 网上有句话说“不懂STL不要说你会C”。STL是C中的优秀作品有了它的陪伴许多底层的数据结构以及算法都不需要自己重新造轮子站在前人的肩膀上健步如飞的快速开发。string类https://legacy.cplusplus.com/reference/string/string/?kwstring这是包含string的全部知识的网站,非常给力1. 为什么学习string类1.1C语言中的字符串C语言中字符串是以’\0’结尾的一些字符的集合为了操作方便C标准库中提供了一些str系列的库函数但是这些库函数与字符串是分离开的不太符合OOP的思想而且底层空间需要用户自己管理稍不留神可能还会越界访问。1.2在OJ中有关字符串的题目基本以string类的形式出现而且在常规工作中为了简单、方便、快捷基本都使用string类很少有人去使用C库中的字符串操作函数。2. 标准库中的string类2.1string类(了解)string类的文档介绍在使用string类时必须包含#include头文件以及using namespace std;2.2auto和范围forauto关键字在这里补充2个C11的小语法方便我们后面的学习。在早期C/C中auto的含义是使用auto修饰的变量是具有自动存储器的局部变量后来这个不重要了。C11中标准委员会变废为宝赋予了auto全新的含义即auto不再是一个存储类型指示符而是作为一个新的类型指示符来指示编译器auto声明的变量必须由编译器在编译时期推导而得。用auto声明指针类型时用auto和auto*没有任何区别但用auto声明引用类型时则必须加当在同一行声明多个变量时这些变量必须是相同的类型否则编译器将会报错因为编译器实际只对第一个类型进行推导然后用推导出来的类型定义其他变量。auto不能作为函数的参数可以做返回值但是建议谨慎使用auto不能直接用来声明数组#includeiostreamusingnamespacestd;intfunc1(){return10;}// 不能做参数voidfunc2(autoa){}// 可以做返回值但是建议谨慎使用autofunc3(){return3;}intmain(){inta10;autoba;autoca;autodfunc1();// 编译报错:rror C3531: “e”: 类型包含“auto”的符号必须具有初始值设定项autoe;couttypeid(b).name()endl;couttypeid(c).name()endl;couttypeid(d).name()endl;intx10;autoyx;auto*zx;automx;couttypeid(x).name()endl;couttypeid(y).name()endl;couttypeid(z).name()endl;return0;}范围for对于一个有范围的集合而言由程序员来说明循环的范围是多余的有时候还会容易犯错误。因此C11中引入了基于范围的for循环。for循环后的括号由冒号“ ”分为两部分第一部分是范围内用于迭代的变量第二部分则表示被迭代的范围自动迭代自动取数据自动判断结束。范围for可以作用到数组和容器对象上进行遍历范围for的底层很简单容器遍历实际就是替换为迭代器这个从汇编层也可以看到。#includeiostream#includestringusingnamespacestd;intmain(){intarray[]{1,2,3,4,5};// C98的遍历for(inti0;isizeof(array)/sizeof(array[0]);i){array[i]*2;}for(inti0;isizeof(array)/sizeof(array[0]);i){coutarray[i]endl;}// C11的遍历for(autoe:array)e*2;for(autoe:array)coute endl;}stringstr(hello world);for(autoch:str){coutch ;}coutendl;return0;string类的常用接口说明1.构造函数string()构造空的string类对象即空字符串string(const char* s)用C-string来构造string类对象string(size_t n, char c)string类对象中包含n个字符cstring(const strings)拷贝构造函数可以在官网上查到2.string类对象的容量操作注意size()与length()方法底层实现原理完全相同引入size()的原因是为了与其他容器的接口保持一致一般情况下基本都是用size()。clear()只是将string中有效字符清空不改变底层空间大小。resize(size_t n) 与 resize(size_t n, char c)都是将字符串中有效字符个数改变到n个不同的是当字符个数增多时resize(n)用0来填充多出的元素空间resize(size_t n, charc)用字符c来填充多出的元素空间。注意resize在改变元素个数时如果是将元素个数增多可能会改变底层容量的大小如果是将元素个数减少底层空间总大小不变。reserve(size_t res_arg0)为string预留空间不改变有效元素个数当reserve的参数小于string的底层空间总大小时reserver不会改变容量大小。3. string类对象的访问及遍历操作4. string类对象的修改操作注意在string尾部追加字符时s.push_back© / s.append(1, c) / s c’三种的实现方式差不多一般情况下string类的操作用的比较多操作不仅可以连接单个字符还可以连接字符串。对string操作时如果能够大概预估到放多少字符可以先通过reserve把空间预留好。5.string类非成员函数其中的getline是解决 cin 读取空格问题的函数 ,好用
STL 和 string
STL简介1. 什么是STLSTL(standard template libaray-标准模板库)是C标准库的重要组成部分不仅是一个可复用的组件库而且是一个包罗数据结构与算法的软件框架。2. STL的版本原始版本Alexander Stepanov、Meng Lee 在惠普实验室完成的原始版本本着开源精神他们声明允许任何人任意运用、拷贝、修改、传播、商业使用这些代码无需付费。唯一的条件就是也需要向原始版本一样做开源使用。HP 版本–所有STL实现版本的始祖。P. J. 版本由P. J. Plauger开发继承自HP版本被Windows Visual C采用不能公开或修改缺陷可读性比较低符号命名比较怪异。RW版本由Rouge Wage公司开发继承自HP版本被C Builder 采用不能公开或修改可读性一般。SGI版本由Silicon Graphics Computer SystemsInc公司开发继承自HP版 本。被GCC(Linux)采用可移植性好可公开、修改甚至贩卖从命名风格和编程 风格上看阅读性非常高。我们后面学习STL要阅读部分源代码主要参考的就是这个版本。3. STL的六大组件STL是一个不可多得的工具, 网上有句话说“不懂STL不要说你会C”。STL是C中的优秀作品有了它的陪伴许多底层的数据结构以及算法都不需要自己重新造轮子站在前人的肩膀上健步如飞的快速开发。string类https://legacy.cplusplus.com/reference/string/string/?kwstring这是包含string的全部知识的网站,非常给力1. 为什么学习string类1.1C语言中的字符串C语言中字符串是以’\0’结尾的一些字符的集合为了操作方便C标准库中提供了一些str系列的库函数但是这些库函数与字符串是分离开的不太符合OOP的思想而且底层空间需要用户自己管理稍不留神可能还会越界访问。1.2在OJ中有关字符串的题目基本以string类的形式出现而且在常规工作中为了简单、方便、快捷基本都使用string类很少有人去使用C库中的字符串操作函数。2. 标准库中的string类2.1string类(了解)string类的文档介绍在使用string类时必须包含#include头文件以及using namespace std;2.2auto和范围forauto关键字在这里补充2个C11的小语法方便我们后面的学习。在早期C/C中auto的含义是使用auto修饰的变量是具有自动存储器的局部变量后来这个不重要了。C11中标准委员会变废为宝赋予了auto全新的含义即auto不再是一个存储类型指示符而是作为一个新的类型指示符来指示编译器auto声明的变量必须由编译器在编译时期推导而得。用auto声明指针类型时用auto和auto*没有任何区别但用auto声明引用类型时则必须加当在同一行声明多个变量时这些变量必须是相同的类型否则编译器将会报错因为编译器实际只对第一个类型进行推导然后用推导出来的类型定义其他变量。auto不能作为函数的参数可以做返回值但是建议谨慎使用auto不能直接用来声明数组#includeiostreamusingnamespacestd;intfunc1(){return10;}// 不能做参数voidfunc2(autoa){}// 可以做返回值但是建议谨慎使用autofunc3(){return3;}intmain(){inta10;autoba;autoca;autodfunc1();// 编译报错:rror C3531: “e”: 类型包含“auto”的符号必须具有初始值设定项autoe;couttypeid(b).name()endl;couttypeid(c).name()endl;couttypeid(d).name()endl;intx10;autoyx;auto*zx;automx;couttypeid(x).name()endl;couttypeid(y).name()endl;couttypeid(z).name()endl;return0;}范围for对于一个有范围的集合而言由程序员来说明循环的范围是多余的有时候还会容易犯错误。因此C11中引入了基于范围的for循环。for循环后的括号由冒号“ ”分为两部分第一部分是范围内用于迭代的变量第二部分则表示被迭代的范围自动迭代自动取数据自动判断结束。范围for可以作用到数组和容器对象上进行遍历范围for的底层很简单容器遍历实际就是替换为迭代器这个从汇编层也可以看到。#includeiostream#includestringusingnamespacestd;intmain(){intarray[]{1,2,3,4,5};// C98的遍历for(inti0;isizeof(array)/sizeof(array[0]);i){array[i]*2;}for(inti0;isizeof(array)/sizeof(array[0]);i){coutarray[i]endl;}// C11的遍历for(autoe:array)e*2;for(autoe:array)coute endl;}stringstr(hello world);for(autoch:str){coutch ;}coutendl;return0;string类的常用接口说明1.构造函数string()构造空的string类对象即空字符串string(const char* s)用C-string来构造string类对象string(size_t n, char c)string类对象中包含n个字符cstring(const strings)拷贝构造函数可以在官网上查到2.string类对象的容量操作注意size()与length()方法底层实现原理完全相同引入size()的原因是为了与其他容器的接口保持一致一般情况下基本都是用size()。clear()只是将string中有效字符清空不改变底层空间大小。resize(size_t n) 与 resize(size_t n, char c)都是将字符串中有效字符个数改变到n个不同的是当字符个数增多时resize(n)用0来填充多出的元素空间resize(size_t n, charc)用字符c来填充多出的元素空间。注意resize在改变元素个数时如果是将元素个数增多可能会改变底层容量的大小如果是将元素个数减少底层空间总大小不变。reserve(size_t res_arg0)为string预留空间不改变有效元素个数当reserve的参数小于string的底层空间总大小时reserver不会改变容量大小。3. string类对象的访问及遍历操作4. string类对象的修改操作注意在string尾部追加字符时s.push_back© / s.append(1, c) / s c’三种的实现方式差不多一般情况下string类的操作用的比较多操作不仅可以连接单个字符还可以连接字符串。对string操作时如果能够大概预估到放多少字符可以先通过reserve把空间预留好。5.string类非成员函数其中的getline是解决 cin 读取空格问题的函数 ,好用