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

C++ STL学习记录(v1)

C++ STL学习记录

  • 一. 什么是STL
    • 1.1 STL的诞生
    • 1.2 STL基本概念
    • 1.3 STL的六大组件
    • 1.4 STL中的容器、算法、迭代器
    • 1.5 容器、算法、迭代器实践

一. 什么是STL


1.1 STL的诞生

  • STL建立的目的就是为了解决软件界复用性的需求。
  • C++的面向对象泛型编程思想,目的就是为了复用性的提升。
  • 大多数情况下,数据结构和算法都未能有一套标准,导致被迫从事大量重复工作
  • 为了建立数据结构和算法的一套标准,诞生了STL

1.2 STL基本概念

  • STL (Standard Template Library)标准模板库
  • STL从广义上分为:容器(container) 算法(algorithm) 迭代器(iterator)
  • 容器算法之间通过迭代器无缝链接。
  • STL几乎所有代码都采用了模板类或者模板函数

1.3 STL的六大组件

STL大体分为六大组件,分别是:容器、算法、迭代器、仿函数、适配器(配接器)、空间配置器。前四个为主要开发常用。

  1. 容器:各种数据结构,如vector、list、deque、set、map等,用来存放数据。
  2. 算法:各种常用的算法、如sort、find、copy、for_each等。
  3. 迭代器:充当容器和算法之间的胶合剂;
  4. 仿函数:行为类似函数,可作为算法的某种策略;
  5. 适配器:一种用来修饰容器或者仿函数或迭代器接口的东西。
  6. 空间配置器:负责空间的配置与管理

1.4 STL中的容器、算法、迭代器

容器:
STL容器就是将运用最广泛的一些数据结构实现出来。
最常用的数据结构:数组,链表,树,栈,队列,集合,映射表等。
这些容器分为序列式容器关联式容器两种:

  • 序列式容器容器:强调值的排序,序列式容器中的每个元素均具有固定的位置。
  • 关联式容器:二叉树结构,各元素之间么有严格的物理上的顺序关系。

算法:
有限的步骤,解决逻辑或数学上的问题,就是算法(Algorithm)
算法分为:质变算法非质变算法

  • 质变算法:是指运算过程中会更改区间内的元素内容,例如拷贝、替换、删除等
  • 非质变算法:是指运算过程中不会更改区间内的元素内容,例如查找、计数、遍历、寻找极值等

迭代器:
提供一种方法,能依序寻访某个容器所含的各个元素,而又无需暴露该容器的内部表示方式。
每个容器都有自己的专属迭代器
迭代器使用非常类似于指针、初学阶段我们可以先将迭代器理解为指针。

迭代器种类:

  • 输入迭代器:对数据的只读访问 ++、==、!=
  • 输出迭代器:对数据的只写访问 ++
  • 前向迭代器:读写操作,并能向前推进迭代器 ++、==、!=
  • 双向迭代器:读写操作,并能向前和向后操作 ++、–
  • 随机访问迭代器:读写操作,可以以跳跃的方式访问任意数据,功能最强的迭代器 ++、–、[n]、-n、<、<=、>、>=

常用的容器中迭代器种类为双向迭代器、和随机访问迭代器。

1.5 容器、算法、迭代器实践

容器:vector | 算法:for_each | 迭代器:vector<int>::iterator

int main() {//创建一个vector容器vector<int> v;//向容器插入数据v.push_back(1);v.push_back(2);v.push_back(3);v.push_back(4);//通过迭代器访问容器中的数据vector<int>::iterator iteratorBegin = v.begin();vector<int>::iterator iteratorEnd = v.end();//第一种遍历方式while (iteratorBegin != iteratorEnd) {cout << *iteratorBegin << endl;iteratorBegin++;}//第二种遍历方式for (vector<int>::iterator i = v.begin(); i < v.end(); i++) {cout << *i << endl;}//第三种,算法遍历for_each(v.begin(), v.end(), [] (int val){cout << val << endl;});return 1;
}

相关文章:

C++ STL学习记录(v1)

C STL学习记录一. 什么是STL1.1 STL的诞生1.2 STL基本概念1.3 STL的六大组件1.4 STL中的容器、算法、迭代器1.5 容器、算法、迭代器实践一. 什么是STL 1.1 STL的诞生 STL建立的目的就是为了解决软件界复用性的需求。C的面向对象和泛型编程思想&#xff0c;目的就是为了复用性的…...

开发中遇到的问题

1.当写一个导出功能时&#xff0c;因为编码写URL地址&参数的时候&#xff0c;用反转字符串的时候换行了&#xff0c;造成地址拼接不成&#xff0c;一直报错&#xff0c;后来发现是编码格式造成的&#xff0c;已解决。 解决方案&#xff1a;不换行或者用 “”拼接 2.当本地…...

Javascript笔记

数据类型 基本类型(primitive value) 简单的数据段&#xff0c;包括 Undefined, Null, Boolean, Number, String初始化只使用2原始字面量形式&#xff0c;如果使用new则会创建Object无法加入新的属性 引用类型(reference value) 可能由多个值构成的对象判断类型 typeofinstanc…...

Elasticsearch(ES)配置及优化

在Elasticsearch中&#xff0c;索引的大小和存储能力取决于多个因素&#xff0c;包括文档大小、索引的分片数、硬件规格、查询负载和其他因素。索引和分片配置&#xff1a;索引和分片的数量和配置会对查询并发性能产生影响。如果索引和分片的数量太少&#xff0c;可能会导致查询…...

一文看懂Java语言与Java生态圈

Java语言与Java生态圈 1、Oracle JDK与Open JDK之间的关系 Oracle JDK Java最早是由SUN公司发明&#xff0c;Oracle JDK之前叫SUN JDK&#xff0c;显而易见&#xff0c;这是在2009年Oracle收购SUN公司之前&#xff0c;收购之后被名为Oracle JDK&#xff0c;实际上&#xff0…...

GitHub 上有什么嵌入式方面的项目?

原文直达,喜欢就点个赞吧&#xff01; GitHub 上有什么嵌入式方面的项目&#xff1f; - CodeAllen的回答 - 知乎 https://www.zhihu.com/question/27835930/answer/2871624679 前言 对于GitHub&#xff0c;可能做互联网开发的同学会更加熟悉&#xff0c;尤其是前端&#xff0…...

【C语言进阶】结构体、位段、枚举和联合

&#x1f466;个人主页&#xff1a;Weraphael ✍&#x1f3fb;作者简介&#xff1a;目前是C语言学习者 ✈️专栏&#xff1a;C语言航路 &#x1f40b; 希望大家多多支持&#xff0c;咱一起进步&#xff01;&#x1f601; 如果文章对你有帮助的话 欢迎 评论&#x1f4ac; 点赞&a…...

markdown和latex常用部分参考@注脚@链接跳转@csdn

文章目录refmarkdown和latex常用部分参考typora文档基础语法扩展语法链接内联链接的方式将链接提取出来链接示例typora的支持LinksInline LinksInternal Links&#x1f388;Reference LinksURLs文章内部跳转(Heading IDs)&#x1f388;My Great Heading注脚(Footnotes)&#x1…...

Java 在二叉树中增加一行

623. 在二叉树中增加一行中等给定一个二叉树的根 root 和两个整数 val 和 depth &#xff0c;在给定的深度 depth 处添加一个值为 val 的节点行。注意&#xff0c;根节点 root 位于深度 1 。加法规则如下:给定整数 depth&#xff0c;对于深度为 depth - 1 的每个非空树节点 cur…...

kubernetes(k8s) 知识总结(第2期)

1. “控制器”思想 kube-controller-manager 是一系列控制器的集合&#xff0c;这些控制器被放在 Kubernetes 项目的 pkg/controller 目录&#xff0c;这些控制器都以独有的方式负责某种编排功能。它们都遵循一个通用的编排模式——控制循环。 以 Deployment 为例介绍它对控…...

windows-Mysql的主从数据库同步设置

复制原有的mysql修改my.ini配置文件 修改端口号修改从数据的地址和从数据库的数据存放地址安装从数据库进入从数据库的bin目录&#xff0c;打开命令窗口输入命令&#xff1a;mysqld.exe install mysql-back --defaults-file "C:\ProgramData\MySQL\MySQL Server 5.7-back\…...

Docker逃逸

文章目录原理环境搭建Docker 环境判断Docker 容器逃逸特权模式逃逸如何判断是否为特权模式逃逸docker.sock挂载逃逸逃逸Remote API未授权访问未授权访问逃逸容器服务缺陷逃逸影响版本环境搭建逃逸脏牛漏洞逃逸参考原理 docker其实就是一个linux下的进程&#xff0c;它通过Name…...

k8s项目部署

k8s命令k8s项目部署部署流程实现导出相应的yaml文件 kubectl create deployment 名字--image镜像-o yaml --dry-runclient > 文件名 例&#xff1a; kubectl create deployment nginx --imagenginx -o yaml --dry-runclient > m1.yaml导出已经部署后的yaml文件 kubectl g…...

Modbus通信协议学习笔记

Modbus主从设备 主控设备&#xff08;Modbus Master&#xff09;&#xff1a;工控机、PLC、触摸屏等等 从设备&#xff08;Modbus Slave&#xff09;&#xff1a;PLC、Modbus采集模块、带485通讯的传感器、仪器仪表等等 Modbus物理接口&#xff1a;串口&#xff08;RS232、RS4…...

ubuntu重启、关机命令

// // // //之前用linux系统&#xff0c; 一键解决也是可以的&#xff0c;反正我每次用命令&#xff08;泪目…&#xff09;&#xff0c;中间崩了好几次&#xff0c;换回win&#xff0c;此篇也做记录 // // // 重启命令 以下所有命令在root根目录下输入&#xff08;普通用户&…...

Xshell 7 连接云服务器的步骤和出现的错误

一、工具准备云服务器Xshell 7二、使用 Xshell 7 连接数据库三、新建会话属性后&#xff0c;没有自动弹出 SSH 用户名要求输入四、SSH 用户身份验证不能输入 Password五、Xshell 连接 centos 7 服务器 报错提示 “ssh服务拒绝了密码&#xff0c;请再试一次“&#xff0c;但是密…...

Python多进程同步——文件锁

多个进程共享同一份资源&#xff08;共享内存、文件等&#xff09;时&#xff0c;会涉及到资源竞争问题。为了解决这种问题&#xff0c;一般采取的措施是进程在访问资源前加锁保护&#xff0c;避免多个进程同时读写。本文介绍的Python文件锁可以用来解决多进程的同步问题。 目录…...

实现 element-plus 表格多选时按 shift 进行连选的功能

前言 element-plus表格提供了多选功能&#xff0c;可单击勾选一条数据&#xff0c;可全选。 现在有个很合理的需求&#xff0c;希望实现类似于文件系统中shift连续选择功能&#xff0c;并且在表格排序后&#xff0c;依照排序后的顺序连选。 一、el-table 多选表格基本使用 1、…...

华为OD机试真题JAVA实现【考古学家】真题+解题思路+代码(20222023)

🔥系列专栏 华为OD机试(JAVA)真题目录汇总华为OD机试(Python)真题目录汇总华为OD机试(C++)真题目录汇总华为OD机试(JavaScript)真题目录汇总文章目录 🔥系列专栏题目输入输出示例一输入输出说明示例二输入输出说明...

Spring3之基于Aspect实现AOP

简介 使用 Aspect 搭配 Spring 可轻松实现 AOP&#xff1b;本章将通过一个完整示例演示如何实现这一功能 实现步骤 修改 beans.xml 配置文件的 schema 部分&#xff1b;可以在 spring-framework-reference.html 文件通过搜索关键字 “/aop” 找到配置 schema&#xff0c;然后…...

SpringBoot+Vue Spring Boot可盈保险合同管理系统管理平台源码【适合毕设/课设/学习】Java+MySQL

系统架构设计### 摘要 随着保险行业的快速发展&#xff0c;传统的手工管理模式已无法满足现代保险业务的高效需求。保险合同管理系统作为保险业务的核心支撑&#xff0c;亟需通过信息化手段提升管理效率&#xff0c;降低人工操作错误率。当前市场上许多保险公司的合同管理仍依赖…...

2026年电工杯比赛思路、Python代码、Matlab代码、论文(持续更新中......)

&#x1f4a5;&#x1f4a5;&#x1f49e;&#x1f49e;欢迎来到本博客❤️❤️&#x1f4a5;&#x1f4a5; &#x1f3c6;博主优势&#xff1a;&#x1f31e;&#x1f31e;&#x1f31e;博客内容尽量做到思维缜密&#xff0c;逻辑清晰&#xff0c;为了方便读者。 ⛳️座右铭&a…...

5分钟掌握RePKG:Wallpaper Engine资源提取与格式转换的终极秘籍

5分钟掌握RePKG&#xff1a;Wallpaper Engine资源提取与格式转换的终极秘籍 【免费下载链接】repkg Wallpaper engine PKG extractor/TEX to image converter 项目地址: https://gitcode.com/gh_mirrors/re/repkg 你是否曾经面对Wallpaper Engine中的PKG资源包感到无从下…...

需求驱动设计:构建可追溯、高质量的FPGA/ASIC开发流程

1. 项目概述&#xff1a;为什么我们需要一场关于“需求驱动设计”的讨论&#xff1f;如果你是一名FPGA或ASIC的设计工程师、项目经理&#xff0c;或者正在向这个领域迈进&#xff0c;那么“项目延期”、“功能bug在流片前夜才被发现”、“需求变更导致架构推倒重来”这些场景&a…...

weave-compose实战:用Docker Compose语法轻松构建多主机容器集群

1. 项目概述与核心价值最近在折腾容器编排&#xff0c;特别是想找一个比Kubernetes更轻量、更贴近Docker原生体验的方案。在GitHub上闲逛时&#xff0c;发现了Adityaraj0421/weave-compose这个项目。乍一看名字&#xff0c;以为是Docker Compose的某个魔改版&#xff0c;但深入…...

FPGA在软件无线电系统中的并行处理与动态重配置技术

1. FPGA在软件无线电系统中的核心价值FPGA&#xff08;现场可编程门阵列&#xff09;已成为现代软件无线电&#xff08;SDR&#xff09;系统的核心处理引擎。与传统DSP处理器相比&#xff0c;FPGA凭借其并行架构和可重构特性&#xff0c;在实时信号处理领域展现出独特优势。在典…...

CH32F103C8T6 vs STM32F103C8T6:程序下载生态深度对比与国产替代实战

CH32F103C8T6与STM32F103C8T6程序下载生态全维度对比与国产化迁移指南 在嵌入式开发领域&#xff0c;MCU的程序下载方式往往决定了开发效率的上限。当工程师从熟悉的STM32平台转向国产CH32时&#xff0c;最直接的"水土不服"往往就发生在烧录环节——同样的SWD接口为何…...

如何高效管理Zotero插件:一站式插件市场完整指南

如何高效管理Zotero插件&#xff1a;一站式插件市场完整指南 【免费下载链接】zotero-addons Zotero Add-on Market | Zotero插件市场 | Browsing, installing, and reviewing plugins within Zotero 项目地址: https://gitcode.com/gh_mirrors/zo/zotero-addons 还在为…...

基于MCP协议与WebDAV构建AI智能体统一数据访问层

1. 项目概述与核心价值最近在折腾个人知识库和自动化工作流时&#xff0c;我又一次被“数据孤岛”问题绊住了脚。手头的信息散落在各种地方&#xff1a;Notion里的项目规划、Obsidian的零散笔记、Google Calendar的日程、甚至是一些本地文件夹里的PDF和图片。想要让这些数据联动…...

AI编程技能自学习:构建Claude与Cursor的智能协同开发环境

1. 项目概述&#xff1a;当Claude遇上Cursor&#xff0c;一场关于AI编程技能的自我进化最近在GitHub上看到一个挺有意思的项目&#xff0c;叫Self-Learning-Claude-Skill。虽然项目描述和正文都还是空的&#xff0c;但光看这个标题和关键词——claude-code、cursor、skills——…...