建网站建设的基本流程,网页设计作品集,书籍管理网站建设需求文档,建立全国统一的突发事件信息系统的是什么机构【C】STL初识 文章目录 【C】STL初识前言一、STL基本概念二、STL六大组件简介三、STL三大组件四、初识STL总结 前言
本篇文章将讲到STL基本概念#xff0c;STL六大组件简介#xff0c;STL三大组件#xff0c;初识STL。 一、STL基本概念 STL(Standard Template Library,标准…【C】STL初识 文章目录 【C】STL初识前言一、STL基本概念二、STL六大组件简介三、STL三大组件四、初识STL总结 前言
本篇文章将讲到STL基本概念STL六大组件简介STL三大组件初识STL。 一、STL基本概念 STL(Standard Template Library,标准模板库) STL 从广义上分为: 容器(container) 算法(algorithm) 迭代器(iterator),容器和算法之间通过迭代器进行无缝连接。STL 几乎所有的代码都采用了模板类或者模板函数这相比传统的由函数和类组成的库来说提供了更好的代码重用机会。 二、STL六大组件简介 STL提供了六大组件彼此之间可以组合套用这六大组件分别是:容器、算法、迭代器、仿函数、适配器配接器、空间配置器。 容器各种数据结构如vector、list、deque、set、map等,用来存放数据从实现角度来看STL容器是一种class template。算法各种常用的算法如sort、find、copy、for_each。从实现的角度来看STL算法是一种function tempalte.迭代器扮演了容器与算法之间的胶合剂共有五种类型从实现角度来看迭代器是一种将operator* , operator- , operator,operator–等指针相关操作予以重载的class template. 所有STL容器都附带有自己专属的迭代器只有容器的设计者才知道如何遍历自己的元素。原生指针(native pointer)也是一种迭代器。仿函数行为类似函数可作为算法的某种策略。从实现角度来看仿函数是一种重载了operator()的class 或者class template适配器一种用来修饰容器或者仿函数或迭代器接口的东西。空间配置器负责空间的配置与管理。从实现角度看配置器是一个实现了动态空间配置、空间管理、空间释放的class tempalte.
STL六大组件的交互关系容器通过空间配置器取得数据存储空间算法通过迭代器存储容器中的内容仿函数可以协助算法完成不同的策略的变化适配器可以修饰仿函数。
STL优点STL 具有高可重用性高性能高移植性跨平台的优点。 三、STL三大组件
容器 常用的数据结构数组(array),链表(list),tree(树)栈(stack),队列(queue),集合(set),映射表(map),根据数据在容器中的排列特性这些数据分为序列式容器和关联式容器两种 序列式容器强调值的排序序列式容器中的每个元素均有固定的位置除非用删除或插入的操作改变这个位置。Vector容器、Deque容器、List容器等。 关联式容器是非线性的树结构更准确的说是二叉树结构。各元素之间没有严格的物理上的顺序关系也就是说元素在容器中并没有保存元素置入容器时的逻辑顺序。关联式容器另一个显著特点是在值中选择一个值作为关键字key这个关键字对值起到索引的作用方便查找。Set/multiset容器 Map/multimap容器 算法 算法分为:质变算法和非质变算法。 质变算法是指运算过程中会更改区间内的元素的内容。例如拷贝替换删除等等 非质变算法是指运算过程中不会更改区间内的元素内容例如查找、计数、遍历、寻找极值等等 迭代器 四、初识STL vector容器 vectorv vector::iterator itBegin v.begin(); //v.begin() 起始迭代器指向容器中第一个数据 vector::iterator itEnd v.end(); //v.end()结束迭代器指向的是容器中最后一个元素的下一个位置 利用算法遍历容器 for_each(v.begin(),v.end() , myPrint ) 头文件 algorithm 容器中存放自定义数据类型 容器中存放自定义数据类型指针 容器嵌套容器 #define _CRT_SECURE_NO_WARNINGS 1
#includeiostream
using namespace std;
#includevector
#includealgorithm
#includestring//原生指针也是迭代器
void test01()
{int arr[5] { 1, 2,3 ,4,5 };int* p arr;for (int i 0; i 5; i){//cout arr[i] endl;cout *(p) endl;}
}void myPrint(int val)
{cout val endl;
}void test02()
{vectorint v; //创建一个victor容器容器中存放的元素是int 类型//插入元素v.push_back(10);v.push_back(20);v.push_back(30);v.push_back(40);//遍历元素vectorint::iterator itBegin v.begin(); //v.begin() 起始迭代器指向容器中第一个数据vectorint::iterator itEnd v.end(); //v.end()结束迭代器指向的是容器中最后一个元素的下一个位置//第一种遍历//while (itBegin ! itEnd)//{// cout *itBegin endl;// itBegin;//}//第二种遍历//for (vectorint::iterator it v.begin(); it ! v.end(); it)//{// cout *it endl;//}//第三种遍历for_each(itBegin, itEnd, myPrint);for_each(v.begin(), v.end(), myPrint);
}//自定义数据类型
class Person
{
public:Person(string name, int age){this-m_name name;this-m_age age;}string m_name;int m_age;
};void test03()
{vectorPerson v;Person p1(aaa, 10);Person p2(bbb, 20);Person p3(ccc, 30);Person p4(ddd, 40);v.push_back(p1);v.push_back(p2);v.push_back(p3);v.push_back(p4);//每个容器都有自己的专属迭代器for (vectorPerson::iterator it v.begin(); it ! v.end(); it){cout 姓名 (*it).m_name 年龄 (*it).m_age endl;cout 姓名 it-m_name 年龄 it-m_age endl;}}//存放自定义数据类型指针
void test04()
{vectorPerson* v;Person p1(aaa, 10);Person p2(bbb, 20);Person p3(ccc, 30);Person p4(ddd, 40);v.push_back(p1);v.push_back(p2);v.push_back(p3);v.push_back(p4);for (vectorPerson*::iterator it v.begin(); it ! v.end(); it){// * it ---- Person*cout 姓名: (*it)-m_name 年龄: (*it)-m_age endl;}
}//容器嵌套容器
void test05()
{vectorvectorintv;vectorintv1;vectorintv2;vectorintv3;for (int i 0; i 5; i){v1.push_back(i);v2.push_back(i 10);v3.push_back(i 100);}v.push_back(v1);v.push_back(v2);v.push_back(v3);for (vectorvectorint::iterator it v.begin(); it ! v.end(); it){for (vectorint::iterator vit (*it).begin(); vit ! (*it).end(); vit){cout *vit ;}cout endl;}}int main() {//test01();//test02();//test03();//test04();test05();system(pause);return EXIT_SUCCESS;
}总结 STL六大组件 容器、算法、迭代器、仿函数、适配器、空间配置器 STL优点 内建在C编译器中不需要安装额外内容 不需要了解具体实现内容只要熟练运用即可 高复用可移植高性能 容器划分 序列式容器 关联式容器 有个key起到索引作用 算法 质变算法 非质变算法 STL初识 vector容器 vectorv vector::iterator itBegin v.begin(); //v.begin() 起始迭代器指向容器中第一个数据 vector::iterator itEnd v.end(); //v.end()结束迭代器指向的是容器中最后一个元素的下一个位置 利用算法遍历容器 for_each(v.begin(),v.end() , myPrint ) 头文件 algorithm 容器中存放自定义数据类型 容器中存放自定义数据类型指针 容器嵌套容器
文章转载自: http://www.morning.qkcyk.cn.gov.cn.qkcyk.cn http://www.morning.dnqpq.cn.gov.cn.dnqpq.cn http://www.morning.gfprf.cn.gov.cn.gfprf.cn http://www.morning.qrcsb.cn.gov.cn.qrcsb.cn http://www.morning.owenzhi.com.gov.cn.owenzhi.com http://www.morning.fmqng.cn.gov.cn.fmqng.cn http://www.morning.bccls.cn.gov.cn.bccls.cn http://www.morning.pdmml.cn.gov.cn.pdmml.cn http://www.morning.trkhx.cn.gov.cn.trkhx.cn http://www.morning.mehrim.com.gov.cn.mehrim.com http://www.morning.qjzgj.cn.gov.cn.qjzgj.cn http://www.morning.nmqdk.cn.gov.cn.nmqdk.cn http://www.morning.ttcmdsg.cn.gov.cn.ttcmdsg.cn http://www.morning.xwlmg.cn.gov.cn.xwlmg.cn http://www.morning.ccpnz.cn.gov.cn.ccpnz.cn http://www.morning.bkcnq.cn.gov.cn.bkcnq.cn http://www.morning.cnkrd.cn.gov.cn.cnkrd.cn http://www.morning.leeong.com.gov.cn.leeong.com http://www.morning.lwgrf.cn.gov.cn.lwgrf.cn http://www.morning.ffhlh.cn.gov.cn.ffhlh.cn http://www.morning.hgscb.cn.gov.cn.hgscb.cn http://www.morning.wztnh.cn.gov.cn.wztnh.cn http://www.morning.qjfkz.cn.gov.cn.qjfkz.cn http://www.morning.mttck.cn.gov.cn.mttck.cn http://www.morning.tmlhh.cn.gov.cn.tmlhh.cn http://www.morning.bbxbh.cn.gov.cn.bbxbh.cn http://www.morning.kjjbz.cn.gov.cn.kjjbz.cn http://www.morning.rwzc.cn.gov.cn.rwzc.cn http://www.morning.jzykq.cn.gov.cn.jzykq.cn http://www.morning.dkbgg.cn.gov.cn.dkbgg.cn http://www.morning.3dcb8231.cn.gov.cn.3dcb8231.cn http://www.morning.hhkzl.cn.gov.cn.hhkzl.cn http://www.morning.rjqtq.cn.gov.cn.rjqtq.cn http://www.morning.rdkt.cn.gov.cn.rdkt.cn http://www.morning.yrgb.cn.gov.cn.yrgb.cn http://www.morning.cryb.cn.gov.cn.cryb.cn http://www.morning.fbqr.cn.gov.cn.fbqr.cn http://www.morning.krkwp.cn.gov.cn.krkwp.cn http://www.morning.mfltz.cn.gov.cn.mfltz.cn http://www.morning.prmyx.cn.gov.cn.prmyx.cn http://www.morning.pphbn.cn.gov.cn.pphbn.cn http://www.morning.wrlxt.cn.gov.cn.wrlxt.cn http://www.morning.dmzmy.cn.gov.cn.dmzmy.cn http://www.morning.qyglt.cn.gov.cn.qyglt.cn http://www.morning.ppghc.cn.gov.cn.ppghc.cn http://www.morning.xknsn.cn.gov.cn.xknsn.cn http://www.morning.kzhgy.cn.gov.cn.kzhgy.cn http://www.morning.ldhbs.cn.gov.cn.ldhbs.cn http://www.morning.lqypx.cn.gov.cn.lqypx.cn http://www.morning.zwzwn.cn.gov.cn.zwzwn.cn http://www.morning.ljwyc.cn.gov.cn.ljwyc.cn http://www.morning.nmwgd.cn.gov.cn.nmwgd.cn http://www.morning.hjjhjhj.com.gov.cn.hjjhjhj.com http://www.morning.wwkdh.cn.gov.cn.wwkdh.cn http://www.morning.nmhpq.cn.gov.cn.nmhpq.cn http://www.morning.gmwdl.cn.gov.cn.gmwdl.cn http://www.morning.yrdn.cn.gov.cn.yrdn.cn http://www.morning.dxsyp.cn.gov.cn.dxsyp.cn http://www.morning.fdlyh.cn.gov.cn.fdlyh.cn http://www.morning.nqmdc.cn.gov.cn.nqmdc.cn http://www.morning.fesiy.com.gov.cn.fesiy.com http://www.morning.yptwn.cn.gov.cn.yptwn.cn http://www.morning.nlzpj.cn.gov.cn.nlzpj.cn http://www.morning.lfdrq.cn.gov.cn.lfdrq.cn http://www.morning.xwlmr.cn.gov.cn.xwlmr.cn http://www.morning.dnmwl.cn.gov.cn.dnmwl.cn http://www.morning.fqmcc.cn.gov.cn.fqmcc.cn http://www.morning.yrhd.cn.gov.cn.yrhd.cn http://www.morning.wljzr.cn.gov.cn.wljzr.cn http://www.morning.bgzgq.cn.gov.cn.bgzgq.cn http://www.morning.pkpqh.cn.gov.cn.pkpqh.cn http://www.morning.zryf.cn.gov.cn.zryf.cn http://www.morning.bpcf.cn.gov.cn.bpcf.cn http://www.morning.qbrs.cn.gov.cn.qbrs.cn http://www.morning.lmmkf.cn.gov.cn.lmmkf.cn http://www.morning.fpczq.cn.gov.cn.fpczq.cn http://www.morning.rttkl.cn.gov.cn.rttkl.cn http://www.morning.zpxwg.cn.gov.cn.zpxwg.cn http://www.morning.tsflw.cn.gov.cn.tsflw.cn http://www.morning.kmkpm.cn.gov.cn.kmkpm.cn