初识 STL

一、概念

STL中文名叫标准模板库,是C++标准库的重要组成部分,是一些“容器”的集合,这些“容器”有list,vector,set,map等,不仅是一个可复用的组件库,而且是一个包罗数据结构与算法的软件框架,STL的目的是标准化组件,这样就不用重新开发,可以使用现成的组件。

二、版本

原始版本:Alexander Stepanov、Meng Lee 在惠普实验室完成的原始版本。

P. J. 版本:由P. J. Plauger开发,继承自HP版本,被Windows Visual C++采用,不能公开或修改,可读性比较低, 符号命名比较怪异。

RW版本:由Rouge Wage公司开发,继承自HP版本,被C++ Builder 采用,不能公开或修改,可读性一般。

SGI版本:由Silicon Graphics Computer Systems,Inc公司开发,继承自HP版本,被gcc(Linux)采用,可移植性好, 可公开、修改,可读性高。

三、六大组件

1. 容器 :各种数据结构

线性结构:现行容器

树形结构:树形结构的容器

哈希结构:哈希结构的容器

2. 通用的算法(sort,search,copy,erase等):与数据类型无关,与数据结构无关

3. 迭代器:类似与指针,容器与算法之间的胶合剂,迭代器是一种将 operator*、operator->、operator++、operator- - 等指针相关操作进行重载的class template,所有STL容器都有自己专属的迭代器,只有容器本身才知道如何遍历自己的元素,原生指也是一种迭代器。

4. 配接器(stack,queue):一种用来修饰容器、仿函数、迭代器接口的东西

5. 函数对象(仿函数):行为类似函数,可作为算法的某种策略,从实现的角度来看,仿函数是一种重载了operator()的class或class template,一般的函数指针也可视为狭义的仿函数

6、配置器(allocators):负责空间配置与管理

容器通过配置器取得数据储存空间,算法通过迭代器存取容器内容,仿函数可以协助算法完成不同的策略变化,配接器可以修饰或套接仿函数。

四、缺陷

1. 不支持线程安全,并发环境下需要我们自己加锁,锁的粒度是比较大 

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

3. STL的使用会有代码膨胀的问题,比如使用vector/vector/vector这样会生成多份代码

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值