C++ 初识STL

STL

  • 1. 初识STL
  • 2. STL相关知识学习网站
  • 3. STL体系结构
  • 4. STL六大组件之间的关系
  • 5. STL六大组件使用例子
  • 6. 初识容器
  • 7. 初识分配器
    • 7.1 其他分配器
    • 7.2 为什么需要其他的分配器

1. 初识STL

       STL全称为标准模板库(Standard Template Library)。设计STL的初衷是为了实现一种可重复利用的东西,以及一种可以制造出”可重复运用的东西”的方法。它与C++ Standard Library并不完全相同,前者是后者的子集,但STL几乎包含了C++标准库的绝大多数内容。STL属于泛型编程(Generic Programming)的重要例子,与面向对象继承编程不同,泛型编程主张将数据和方法分开,两者分开开发,但两者采用迭代器进行连接

  • C++标准库头文件无.h
  • 标准库的所有新式组件均放在std命名空间内,可采用using namespace std 或 using std::组件

2. STL相关知识学习网站

  • https://cplusplus.com/
    在这里插入图片描述

  • https://zh.cppreference.com/
    在这里插入图片描述

3. STL体系结构

       STL由六大组件构成,分别为容器、算法、迭代器、仿函数、适配器、分配器

  1. 容器(containers):各种数据结构,例如vector、list、deque、set、map
  2. 算法 (algorithms):各种常用算法,操作容器中的元素,如sort,search,copy,erase…
  3. 迭代器( iterators) :扮演容器与算法之间的胶合剂,是所谓的“泛型指针”
  4. 仿函数( functors) :行为类似函数,可作为算法的某种策略( policy)
  5. 配接器( adapters) :又称适配器,一种用来修饰容器( containers)或仿函数( functors),将一个类的接口转换为另一个类的接口,使得原本不兼容不能合作的类可以一起合作
  6. 配置器( allocators) :负责空间配置与管理。从实现的角度来看,配置器是一个实现了动态空间配置、空间管理、空间释放的class template。

4. STL六大组件之间的关系

       容器通过空间配置器分配内存空间,存储该种数据结构类型的数据,算法通过迭代器操作容器内的数据集,仿函数可以协助算法完成不同的策略变化,配接器可以修饰或套接仿函数

在这里插入图片描述

5. STL六大组件使用例子

       下例使用了容器、算法、迭代器、仿函数、适配器、分配器。其中,分配器allocator可以不写,源码中由默认的分配器。
在这里插入图片描述

6. 初识容器

序列型容器:数组(array),动态数组(vector),双向队列(deque),双向链表(list),单向链表(forward list),单向队列(queue),栈(stack)。插入快,查找慢。

  • 数组(array):提前分配好固定大小的数组,不可扩充;
  • 动态数组(vector):可向尾部填充元素,数组大小可变。当数组空间不够时,分配器会分配一个更大的内存,然后进行数据拷贝;
  • 双向队列(deque):头部、尾部均可入队出队;
  • 双向链表(list):可双向查找的链表;
  • 单向链表(forward list):仅可单向查找的链表;
  • 单向队列(queue):先进先出,只能在队尾进,只能在队头出(源码中用deque实现),不提供迭代器;
  • 栈(stack):先进后出,只能在栈顶进或出(源码中用deque实现),不提供迭代器;
    在这里插入图片描述
    关系型容器:Set(元素不可重复)、Map(key不可重复),内部采用红黑树实现。Multiset 和Multimap分别表示元素可重复和key可重复。插入慢,查找快。
    在这里插入图片描述
    无序型容器:Unordered Set,Unordered Map。采用hash表实现索引。也是关联型容器,查找快。
    在这里插入图片描述

7. 初识分配器

       分配器用于给各种容器分类存放数据的内存空间,标准库提供默认的空间分配器std::allocator,当然标准库以外的有提供其他分配器,需要自行包含头文件#include<ext\…>。不建议直接使用分配器分配容器以外的内存,因为其不好用,需记忆分配多少内存,释放时也许表明释放多少内存。建议容器之外分配内存采用new/delete,malloc/free

7.1 其他分配器

       std::allocator之外的分配器:

#include<ext\array_allocator.h>
#include<ext\mt_allocator.h>
#include<ext\debug_allocator.h>
#include<ext\pool_allocator.h>
#include<ext\bitmap_allocator.h>
#include<ext\malloc_allocator.h>
#include<ext\new_allocator.h>

不同分配器分配内存并释放内存:需要指明申请内存大小,以及释放内存大小
在这里插入图片描述

7.2 为什么需要其他的分配器

       无论是new操作符,还是空间分配器allocator,本质上都是调用malloc进行内存分配;delete 和deallocator,本质上时调用free进行内存释放。通过 malloc 分配的内存,会在内存前后加上 cookie,以记录内存分配的总大小。因此,malloc每次分得的内存大小总是大于表面上申请的内存大小(申请的内存大小+该块内存的cookie信息)。当频繁多次申请小块内存,则每小块内存均会附带一个cookie,效率很低。STL默认的std::allocator只是以全局的operator new完成allocate(),没有任何特殊设计。
在这里插入图片描述
在这里插入图片描述
        为了提高内存使用效率,也就是要减少malloc的次数。下例分配器为G2.9版本的alloc(目前的__pool_alloc采用16个链表管理内存,每个链表管理同样大小的内存块,0号链表每块内存为8字节,1号链表每块内存为16字节,依次以8的倍数增长。当程序需要用到某一个大小的内存块时,首先看链表中是否有该大小的内存块链表,如果没有则一次性malloc申请一大块,只有一个cookie信息,然后切割为若干个该大小的小内存块,用单向链表连接。
在这里插入图片描述
在这里插入图片描述

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.rhkb.cn/news/153967.html

如若内容造成侵权/违法违规/事实不符,请联系长河编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

【Java 进阶篇】CSS 选择器详解

CSS&#xff08;层叠样式表&#xff09;是一种用于描述网页上元素样式的语言。要想有效地使用CSS&#xff0c;了解CSS选择器是至关重要的&#xff0c;因为它们允许你选择要应用样式的HTML元素。在本文中&#xff0c;我们将详细介绍CSS选择器的各种类型和用法&#xff0c;以便你…

分库分表(3)——ShardingJDBC实践

一、ShardingSphere产品介绍 Apache ShardingSphere 是一套开源的分布式数据库中间件解决方案组成的生态圈&#xff0c;它由 JDBC、Proxy 和 Sidecar&#xff08;规划中&#xff09;这 3 款相互独立&#xff0c;却又能够混合部署配合使用的产品组成。 它们均提供标准化的数据分…

基于YOLOv8模型的足球目标检测系统(PyTorch+Pyside6+YOLOv8模型)

摘要&#xff1a;基于YOLOv8模型的足球目标检测系统可用于日常生活中检测与定位足球目标&#xff0c;利用深度学习算法可实现图片、视频、摄像头等方式的目标检测&#xff0c;另外本系统还支持图片、视频等格式的结果可视化与结果导出。本系统采用YOLOv8目标检测算法训练数据集…

IDEA的使用(三)Debug(断点调试)(IntelliJ IDEA 2022.1.3版本)

编程过程中如果出现错误&#xff0c;需要查找和定位错误时&#xff0c;借助程序调试可以快速查找错误。 编写好程序后&#xff0c;可能出现的情况&#xff1a; 1.没有bug。 使用Debug的情况&#xff1a; 2.运行后&#xff0c;出现错误或者异常信息&#xff0c;但是通过日志文件…

Linux shell编程学习笔记9:字符串运算 和 if语句

Linux Shell 脚本编程和其他编程语言一样&#xff0c;支持算数、关系、布尔、字符串、文件测试等多种运算&#xff0c;同样也需要进行根据条件进行流程控制&#xff0c;提供了if、for、while、until等语句。 上期学习笔记中我们研究了字符串数据的使用&#xff0c;今天我们研…

win1011安装MG-SOFT+MIB+Browser+v10b

文章目录 安装MG-SOFTSNMP服务配置安装MG-SOFT启动MIB-Browser以及错误解决MIB Browser使用 安装MG-SOFT win10和win11安装基本一样&#xff0c;所以参照下面的操作即可&#xff01; SNMP服务配置 打开设置&#xff0c;应用和功能&#xff0c;可选功能&#xff0c;选择添加功…

2023年【G1工业锅炉司炉】考试题及G1工业锅炉司炉模拟考试

题库来源&#xff1a;安全生产模拟考试一点通公众号小程序 2023年G1工业锅炉司炉考试题为正在备考G1工业锅炉司炉操作证的学员准备的理论考试专题&#xff0c;每个月更新的G1工业锅炉司炉模拟考试祝您顺利通过G1工业锅炉司炉考试。 1、【多选题】TSGG0001-2012《锅炉安全技术监…

【OSPF宣告——network命令与多区域配置实验案例】

个人名片&#xff1a; &#x1f43c;作者简介&#xff1a;一名大二在校生&#xff0c;喜欢编程&#x1f38b; &#x1f43b;‍❄️个人主页&#x1f947;&#xff1a;小新爱学习. &#x1f43c;个人WeChat&#xff1a;hmmwx53 &#x1f54a;️系列专栏&#xff1a;&#x1f5bc…

【Vue】vscode格式刷插件Prettier以及配置项~~保姆级教程

文章目录 前言一、下载插件二、在项目内创建配置文件1.在根目录创建&#xff0c;src同级2.写入配置3.每个字段含义 总结 前言 vscode格式刷&#xff0c;有太多插件了&#xff0c;但是每个的使用&#xff0c;换行都不一样。 这里我推荐一个很多人都推荐了的Prettier 一、下载插…

爬取微博热榜并将其存储为csv文件

&#x1f64c;秋名山码民的主页 &#x1f602;oi退役选手&#xff0c;Java、大数据、单片机、IoT均有所涉猎&#xff0c;热爱技术&#xff0c;技术无罪 &#x1f389;欢迎关注&#x1f50e;点赞&#x1f44d;收藏⭐️留言&#x1f4dd; 获取源码&#xff0c;添加WX 目录 前言1.…

Kafka日志索引详解以及生产常见问题分析与总结

Kafka 的核心集群机制&#xff0c;重点保证了在复杂运行环境下&#xff0c;整个 Kafka 集群如何保证 Partition 内消息 的一致性。这就相当于一个军队&#xff0c;有了完整统一的编制。但是&#xff0c;在进行具体业务时&#xff0c;还是需要各个 Broker 进行分工&#xff0c;…

Mac热门软件推荐Paste mac 中文激活版 剪切板工具

Paste for Mac是一款运行在Mac OS平台上的剪切板小工具。它拥有华丽的界面效果&#xff0c;并且每一条记录可显示&#xff08;预览&#xff09;文本、图片等记录的完整内容。此外&#xff0c;Paste for Mac可以记录最近指定条数的剪切板信息&#xff0c;方便用户随时调用&#…

【opencv】windows10下opencv4.8.0-cuda版本源码编译教程

【opencv】windows10下opencv4.8.0-cuda版本源码编译教程 提示:博主取舍了很多大佬的博文并亲测有效,分享笔记邀大家共同学习讨论 文章目录 【opencv】windows10下opencv4.8.0-cuda版本源码编译教程前言准备工具cuda/cudnncmakeopencv4.5.0opencv_contrib CMake编译VS2019编译可…

【Java 进阶篇】CSS盒子模型详解

CSS盒子模型是网页布局的基础之一&#xff0c;它定义了HTML元素在页面上的占用空间和相互关系。理解CSS盒子模型对于构建各种类型的网页布局至关重要。在本文中&#xff0c;我们将深入探讨CSS盒子模型的各个方面&#xff0c;包括盒子模型的概念、属性和如何使用它们来控制元素的…

Data security.隐私保护-多方安全计算技术基础

文章目录 Data security.隐私保护-多方安全计算技术基础一、多方安全计算的背景1.定义2.分类2.1不诚实参与方数量2.2敌手行为2.3敌手计算能力2.4输出可达性2.5计算模型2.6腐化策略&#xff08;攻击者确定攻破并控制参与方的策略&#xff09;2.7通信网络 3.设计方法3.1秘密共享&…

如何在Apache和Resin环境中实现HTTP到HTTPS的自动跳转:一次全面的探讨与实践

&#x1f337;&#x1f341; 博主猫头虎 带您 Go to New World.✨&#x1f341; &#x1f984; 博客首页——猫头虎的博客&#x1f390; &#x1f433;《面试题大全专栏》 文章图文并茂&#x1f995;生动形象&#x1f996;简单易学&#xff01;欢迎大家来踩踩~&#x1f33a; &a…

设计模式 - 观察者模式

目录 一. 前言 二. 实现 三. 优缺点 一. 前言 观察者模式属于行为型模式。在程序设计中&#xff0c;观察者模式通常由两个对象组成&#xff1a;观察者和被观察者。当被观察者状态发生改变时&#xff0c;它会通知所有的观察者对象&#xff0c;使他们能够及时做出响应&#xf…

rustlings本地开发环境配置

克隆自己的仓库 首先我们要在github上找到自己仓库并把它克隆到本地 git clone https://github.com/LearningOS/rust-rustlings-2023-autumn-******.git下载插件 rust-analyzer和Git Graph一个可以用来解析rust代码&#xff0c;另一个可以可视化管理git代码库 下载rustling…

基于安卓android微信小程序音乐播放器

运行环境 小程序前端框架&#xff1a;uniapp 小程序运行软件&#xff1a;微信开发者 后端技术:javaSsm(SpringSpringMVCMyBatis)vue.js 后端开发环境:idea/eclipse 数据库:mysql 项目介绍 音乐播放器小程序的设计主要是对系统所要实现的功能进行详细考虑&#xff0c;确定所要…

SpringCloud学习二

基本介绍&#xff1a; Eureka Server&#xff08;Eureka 服务端&#xff09;是Netflix开源的一款用于构建分布式系统中的服务发现和注册中心的组件。它在微服务架构中扮演着关键的角色&#xff0c;允许不同的微服务应用程序注册自己&#xff0c;并查询其他服务的位置信息&…