C++ 初识STL

news2024/11/15 11:15:06

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.coloradmin.cn/o/1074673.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

关于VMware Workstation Pro中虚拟机无法连接外网问题解决

解决方案 1.虚拟机设置 打开虚拟机设置&#xff0c;将网络设备器修改为NAT模式。注意如果是克隆的多个虚拟机&#xff0c;需要将高级&#xff08;V&#xff09;里面的mac地址进行重新生成。 2.配置虚拟网络编辑器 进入虚拟网络编辑器后&#xff0c;将子网和子网掩码进行修…

安卓玩机----展讯芯片机型解锁 读写分区工具 操作步骤解析

国内机型大都使用高通和MTK芯片。展讯芯片使用的较少。相对来说高通和mtk机型解锁以及读取分区工具较多。展讯的几乎没有。目前有大佬开发出了一款展讯芯片解锁 与读写分区工具.开源的tools 官方分享说明&#xff1a; 是一款专为 Windows 计算机设计的免费、用户友好的工具&am…

性价比高的项目管理软件推荐:哪个更适合您?

如今&#xff0c;企业管理软件层出不穷&#xff0c;面对诸多企业管理软件&#xff0c;我们要如何去进行选择。产品的功能都大同小异&#xff0c;当面对如此之多的“衍生品”&#xff0c;我认为首先要考虑的就是性价比。当产品的功能要求都能够满足时&#xff0c;性价比无疑是最…

【Linux】Linux 之用户管理

Linux 之用户管理 1.Linux 下的用户2.配置文件3.用户管理3.1 useradd3.1.1 创建用户并指定用户 ID3.1.2 指定用户的主目录3.1.3 指定用户的主组 3.2 adduser3.3 userdel3.4 密码文件3.4.1 字段含义解释3.4.2 给用户添加密码 3.5 其他与用户相关的命令 4.修改用户的信息4.1 user…

2.6 方法

思维导图&#xff1a; 2.6.1 什么是方法 ### 2.6.1 什么是方法 **定义**: - 方法就是一段可以重复调用的代码&#xff0c;使得程序的可读性、可维护性都得以提高。 **示例**: - 假设有一个游戏中需要反复发射炮弹。而发射炮弹的代码有100行。为了避免在程序中多次写下这100…

Java架构师系统架构设计性能评估

目录 1 导论2 架构评估基础系统性能衡量的基本指标2.1 系统性能的指标2.2 数据库指标2.3 并发用户数2.4 网络延迟2.4 系统吞吐量2.5 资源性能指标3 架构评估基础服务端性能测试3.1基准测试3.2 负载测试3.3 压力测试3.4 疲劳强度测试3.5 容量测试1 导论 本章的主要内容是掌握架构…

【Java】微服务——RabbitMQ消息队列(SpringAMQP实现五种消息模型)

目录 1.初识MQ1.1.同步和异步通讯1.1.1.同步通讯1.1.2.异步通讯 1.2.技术对比&#xff1a; 2.快速入门2.1.RabbitMQ消息模型2.4.1.publisher实现2.4.2.consumer实现 2.5.总结 3.SpringAMQP3.1.Basic Queue 简单队列模型3.1.1.消息发送3.1.2.消息接收3.1.3.测试 3.2.WorkQueue3.…

【Linux升级之路】7_进程信号

目录 一、【Linux初阶】信号入门 | 信号基本概念信号产生核心转储二、【Linux初阶】信号入门2 | 信号阻塞、捕捉、保存 一、【Linux初阶】信号入门 | 信号基本概念信号产生核心转储 链接&#xff1a; 【Linux初阶】信号入门 | 信号基本概念信号产生核心转储 二、【Linux初阶】…

奖品定制经营商城小程序的作用是什么

奖品是激励人员团体很好的方式&#xff0c;也是荣誉象征&#xff0c;奖牌、奖杯、高端礼盒等&#xff0c;同时市场中团体非常多&#xff0c;其需求也是很多&#xff0c;尤其定制方面&#xff0c;就更是不用说。 对奖品定制企业来说&#xff0c;除了线下门店获客经营外&#xf…

使用BAPI_NETWORK_COMP_*实现生产订单组件的增删改查

1、文档说明 对于生产订单组件的增删改有多种办法&#xff0c;比较常用的有使用内部函数CO_XT_COMPONENT_*&#xff0c;有改造BAPI_ALM_ORDER_MAINTAIN来实现&#xff0c;各有千秋。 本文档介绍&#xff0c;通过PS的BAPI_NETWORK_COMP_*系列BAPI&#xff0c;来实现常见的组件…

单链表习题(对应章节chapter2)

题目1&#xff1a;链表的中间结点 题目来源&#xff1a;leetcode链表的中间结点 第一种思路分析&#xff1a;考虑指针移动到相应的位置来做 参考代码&#xff1a;位置&#xff08;/chapter2/c/middle-link-list-node/lc1.cc&#xff09; #include <stdio.h> extern &qu…

Linux 查看是否安装memcached

telnet 127.0.0.1 11211这样的命令连接上memcache&#xff0c;然后直接输入stats就可以得到memcache服务器的版本 安装memcached &#xff1a; sudo apt-get install memcached

使用HTTP请求操作elastic search

创建索引 获取索引相关信息 查看所有索引 删除索引 向指定索引添加文档 创建文档时指定id 根据id查询doc 查询一个doc下的所有文档

面试算法22:链表中环的入口节点(2)

题目 如果一个链表中包含环&#xff0c;那么应该如何找出环的入口节点&#xff1f;从链表的头节点开始顺着next指针方向进入环的第1个节点为环的入口节点。 例如&#xff0c;在如图4.3所示的链表中&#xff0c;环的入口节点是节点3。 分析 第1步&#xff1a;确认是否包含环…

Java8实战-总结39

Java8实战-总结39 默认方法解决冲突的规则解决问题的三条规则选择提供了最具体实现的默认方法的接口冲突及如何显式地消除歧义菱形继承问题 小结 默认方法 解决冲突的规则 Java语言中一个类只能继承一个父类&#xff0c;但是一个类可以实现多个接口。随着默认方法在Java 8中引…

核货宝:服装店收银系统如何选择?收银系统选购指南!

对于各行各业而言&#xff0c;收银系统都是必备的工具。特别是对于像服装店这样的零售门店来说&#xff0c;选择一套适合的收银系统尤为重要。在选择收银系统时&#xff0c;有一些关键的技巧需要注意&#xff0c;以达到软硬件合理搭配、节省开支的目的。下面将分享四个选购服装…

MAC版Gradle构建Spring5.X源码阅读环境

前言&#xff1a; 三年前鄙人有幸在现已几乎报废的Window的DELL中搭建过Spring源码环境&#xff0c;今天&#xff0c;Mac版的搭建&#xff0c;来了。 本篇文章环境搭建&#xff1a;Spring5.2.1 Gradle5.6.3-all jdk8 IDEA2022.3版本 文章目录 1、Spring源码下载2、Gradle下载…

设计模式 - 行为型模式:策略模式(概述 | 案例实现 | 优缺点 | 使用场景)

目录 一、行为型模式 1.1、策略模式 1.1.1、概论 1.1.2、案例实现 1.1.3、优缺点 1.1.4、使用场景 一、行为型模式 1.1、策略模式 1.1.1、概论 策略模式设计的每一个算法都封装了起来&#xff0c;使他们可以相互替换&#xff0c;通过一个对象委派不同的算法给相应的客户…

Dubbo 环境隔离

通过标签实现流量隔离环境&#xff08;灰度、多套开发环境等&#xff09; 无论是在日常开发测试环境&#xff0c;还是在预发生产环境&#xff0c;我们经常都会遇到流量隔离环境的需求。 在日常开发中&#xff0c;为了避免开发测试过程中互相干扰&#xff0c;我们有搭建多套独…

基于AlexNet深度学习网络的智能垃圾分类系统matlab仿真

目录 1.算法运行效果图预览 2.算法运行软件版本 3.部分核心程序 4.算法理论概述 4.1、基于AlexNet深度学习网络的智能垃圾分类系统概述 4.2、基于AlexNet深度学习网络的智能垃圾分类系统主要原理 5.算法完整程序工程 1.算法运行效果图预览 2.算法运行软件版本 matlab20…