• STL函数库的讲解(1)


    1.什么是STL?

    STL英文全称 standard template library,中文可译为标准模板库或者泛型库,其包含有大量的模板类和模板函数,是 C++ 提供的一个基础模板的集合,用于完成诸如输入/输出、数学计算等功能。

    虽说STL主要出现到C++中,但在被引入C++之前该技术就已经存在了很长时间。STL的代码从广义上讲分为三类:algorithm(算法)、container(容器)和iterator(迭代器),几乎所有的代码都采用了模板类和模板函数的方式,这相比于传统的由函数和类组成的库来说提供了更好的代码重用机会。

    STL 最初由惠普实验室开发,于 1998 年被定为国际标准,正式成为 C++ 程序库的重要组成部分。值得一提的是,如今STL 已完全被内置到支持 C++ 的编译器中,无需额外安装,这可能也是 STL 被广泛使用的原因之一。

    在C++标准中,STL被组织为下面的13个头文件:

    <algorithm>
    <deque>
    <functional>
    <iterator>
    <vector>
    <list>
    <map>
    <memory>
    <numeric>
    <queue>
    <set>
    <stack>
    <utility>
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13

    2.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.

  • 相关阅读:
    小谈设计模式(23)—桥接模式
    【C基础篇】选择结构与循环控制
    一点C知识:数据类型和内存地址。
    算法题中常用的工具类的方法(Java)
    8款提高小团队协作效率的app软件,你用过几款?
    相同执行计划,为何有执行快慢的差别
    C++多线程 task--std::promise和std::future
    TCP 和 UDP 的 Socket 调用
    鸿蒙常用三方库地址一览
    科技企业如何做到FTP数据安全保护
  • 原文地址:https://blog.csdn.net/lzx_xzl_______/article/details/126822230