当前位置: 首页 > news >正文

企业网站备案 过户中国建设银行网站的主要功能

企业网站备案 过户,中国建设银行网站的主要功能,天津seo优化公司哪家好,网站逻辑结构【C】STL初识 文章目录 【C】STL初识前言一、STL基本概念二、STL六大组件简介三、STL三大组件四、初识STL总结 前言 本篇文章将讲到STL基本概念,STL六大组件简介,STL三大组件,初识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
#include<iostream>
using namespace std;
#include<vector>
#include<algorithm>
#include<string>//原生指针也是迭代器
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()
{vector<int> v; //创建一个victor容器,容器中存放的元素是int 类型;//插入元素v.push_back(10);v.push_back(20);v.push_back(30);v.push_back(40);//遍历元素vector<int>::iterator itBegin = v.begin();  //v.begin() 起始迭代器,指向容器中第一个数据vector<int>::iterator itEnd = v.end();  //v.end();结束迭代器,指向的是容器中最后一个元素的下一个位置//第一种遍历//while (itBegin != itEnd)//{//	cout << *itBegin << endl;//	itBegin++;//}//第二种遍历//for (vector<int>::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()
{vector<Person> 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 (vector<Person>::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()
{vector<Person*> 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 (vector<Person*>::iterator it = v.begin(); it != v.end(); it++){// * it ---- Person*cout << "姓名:" << (*it)->m_name << "年龄:" << (*it)->m_age << endl;}
}//容器嵌套容器
void test05()
{vector<vector<int>>v;vector<int>v1;vector<int>v2;vector<int>v3;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 (vector<vector<int>>::iterator it = v.begin(); it != v.end(); it++){for (vector<int>::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.yayakq.cn/news/476177/

相关文章:

  • 做流量的网站中国建设网站下载安装
  • 网站的栏目和板块系统网站有哪些
  • 网站开发下单功能网站建设项目报告
  • 做细分行业信息网站网页传奇开服表
  • 海口网站建设方案报价logo图标设计免费
  • 上海建设网站制wordpress 产品属性tag
  • 广告设计网站排行榜前十名公众号模板编辑器
  • 虚拟币挖矿网站开发潍坊市企业网站建设
  • 南充网站建设狐灵网络360的网站怎么做
  • 网站忧化 优帮云金华建设网
  • 站长工具seo综合查询推广做区块链的网站
  • 百度收录网站左侧图片怎么提高网站的权重
  • o2o 网站建工网论坛
  • a站播放量最高的视频东圃手机网站制作费用
  • 长春网站优化公司html5企业网站赏析
  • 在网站文字上做超链接ui设计师需要掌握什么
  • 汽车网站正在建设中模板凡科官网登录
  • 网站tdk优化wordpress固定连接类型
  • 宁波市环境建设保护局网站wordpress 行间距
  • 双鸭山建设网站东莞市建设公共交易中心网站
  • 常用来做网站首页的是微盟集团是干什么的
  • 网站建设任务清单东莞网站建设方案咨询
  • 排名好的成都网站建设网站建设旗帜条幅
  • 网站域名使用费马鞍山网站建设报价
  • 网站建设合同用贴印花税吗中文域名注册费用标准
  • 延庆上海网站建设网络规划设计师备考心得
  • 高端网站定制费用是多少网站内链seo
  • 网站用户体验是什么商标如何自己注册
  • 企业网站群建设模式郁金香导航 汕头大学网址大全
  • tp5网站文档归档怎么做官方网站在家做兼职