STL简介

本文介绍了STL(标准模板库)在C++中的地位,包括其起源、六大组件(如内存池、容器等)、在编程中的重要性,以及如何学习和使用STL。同时讨论了STL的缺陷,如更新缓慢、不支持线程安全和可能导致代码膨胀等问题。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

1. STL

1.1 STL介绍
  • STL的定义
    STL(standard template libaray-标准模板库)是C++标准库的重要组成部分,不仅是一个可复用的组件库,而且是一个包罗数据结构与算法的软件框架

  • STL的版本

    1. 原始HP版本:
      Alexander Stepanov、Meng Lee 在惠普实验室完成的原始版本,本着开源精神,他们声明允许任何人任意运用、拷贝、修改、传播、商业使用这些代码,无需付费。唯一的条件就是也需要向原始版本一样做开源使用。 HP 版本–所有STL实现版本的始祖。
    2. P. J. 版本
      由P. J. Plauger开发,继承自HP版本,被Windows Visual C++采用,不能公开或修改,缺陷:可读性比较低,符号命名比较怪异。
    3. RW版本
      由Rouge Wage公司开发,继承自HP版本,被C+ + Builder 采用,不能公开或改,可读性一般。
    4. SGI版本
      由Silicon Graphics Computer Systems,Inc公司开发,继承自HP版 本。被GCC(Linux)采用,可移植性好,可公开、修改甚至贩卖,从命名风格和编程 风格上看,阅读性非常高。我们后面学习STL要阅读部分源代码,主要参考的就是这个版本。
1.2 STL的六大组件

STL有六大组件,分别是:

  1. 空间配置器(内存池):allocator
  2. 容器(数据结构):string/vector/list/deque/map/set/multimap/mutilset
  3. 配接器:stack/queue/priority_queue
  4. 仿函数:greater/less/…
  5. 算法:find/swap/reverse/soer/merge/…
  6. 迭代器:iterator/const_iterator/reverse_iterator/const_reverse_iterator
1.3 STL的重要性

无论是在OJ平台上,还是许多公司的面试中,都会涉及到STL的内容,网络上有句话:不懂STL,不要说你会C++。
STL是C++中的优秀作品,有了它,许多底层的数据结构和算法都不需要自己重新造轮子了,让我们得以站在前人的肩膀上。

1.4 学习STL

学习STL,分为三步:

  1. 能用:熟练使用STL
  2. 明理:了解泛型技术的内涵和STL的学理乃至实作
  3. 能扩展:能够根据STL的风格规范,自己扩充STL

学习STL推荐两本书:《STL源码剖析》和《Effective C++》。源码剖析这本书建议C++初阶结束或者进阶的时候看。

1.5 STL的缺陷
  1. STL库的更新太慢了。这个得严重吐槽,上一版靠谱是C++98,中间的C++03基本一些修订。C++11出来已经相隔了13年,STL才进一步更新。

  2. STL现在都没有支持线程安全。并发环境下需要我们自己加锁。且锁的粒度是比较大的。

  3. STL极度的追求效率,导致内部比较复杂。比如类型萃取,迭代器萃取。

  4. STL的使用会有代码膨胀的问题,比如使用vector/vector/vector这样会生成多份代码,当然这是模板语法本身导致的。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值