关于STL与泛型编程学习感想一(博览网)

C++标准库与泛型编程

泛型编程(Generic Programming)就是使用模板(template)为主要工具来编写程序。

这是一种语言机制,能够帮助实现一个通用的标准容器。

C++标准模板库STL(Standard Template Library)

标准库以header files形式呈现。能看到所有源代码

C++标准库的header files 不带副挡名(.h)旧式的仍然可用。

新式headers内组件封装于std

编译器版本对C++标准库没有影响

常用的标准库参考网站:

CPlusPlus.com                  CppReference.com                    gcc.gnu.org

参考书籍:

The C++ Standard Library                      STL源码剖析(侯捷)

STL六大部件:容器、分配器、算法、迭代器、适配器、仿函数

六大部件关系如下图所示



#include

#include

#include

#include

using namespace std;

int main()

{

int ia[6]={27,210,12,47,109,83};

vector>vi(ia,ia+6);//容器中的两种数据类型要匹配,这里使用了容器和分配器

cout<(),40)));/*使用了算法,仿函数,适配器,迭代器*/

return 0;

}



根据不同算法,不同复杂度选择容器

前闭后开区间[ 闭] (开 )  [  )      容器不一定是连续空间

begin指向第一个元素的起点,end指向最后一个元素的下一个位置

(C++11) range-based for statement

for(decl :coll){statement }    //coll>-decl

for (int i:{2,3,5,7,9,13,17,19})

{cout<

auto keyword

auto(since c++11)

list c;

...

auto ite=find(c.begin(),c.end(),target);  //list::iterator ite;

容器结构与分类

序列式容器(排列有一定秩序),关联式容器(key适合做快速查找)、UNordered containers(不定序容器,前身是关联式容器 )

序列式容器:数组array(连续空间,固定内存,不能再扩充)、Vector(向量,前面固定,后面还可以扩充)、Deque(双向队列,两端都可扩充)、链表List(不连续,用指针相连,双向环状链表)Forward-List(单向链表)

关联式容器:set/multiset(set中key不可重复,multiset可以|后面map相同) (key就是vault)二分树(高度平衡)map/multimap(有key和vault)在STL中关联容器使用红黑树来实现,因为不是顺序结构,因而不能使用上面提到的push和pop函数,使用insert和erase函数来实现元素的插入删除操作。关联容器支持通过键来高效地查找和读取元素,两个基本的关联容器类型是map和set。map的元素以键-值(key-value)对的形式组织:键用于元素在map中的索引,而值则表示所存储和读取的数据。set仅包含一个键,并有效地支持关于某个键是否存在的查询。map可理解为字典,set可理解为一类元素的集合。关联容器和顺序容器的本质差别在于:关联容器通过键(key)存储和读取元素,而顺序容器则通过元素在容器中的位置顺序存储和访问元素。set 和 map 类型的对象所包含的元素都具有不同的键,不允许为同一个键添加第二个元素。如果一个键必须对应多个实例,则需使用 multimap 或 multi set,这两种类型允许多个元素拥有相同的键。

不定序容器:  hashtable、separate chaining、UNordered set/multiset、UNordered map/multimap

每个单元独立(每段测试独立放一个namespace)

测试程序变量声明不放在最前面,用之前声明

设S表示一种容器类型(如:vector),s1、s2都是S类型的实例,容器都具有如下基本功能:

S s1  容器的默认构造函数,用于构造一个没有任何元素的空容器。

s1 op s2  对两容器之间的元素按字典序进行比较,op表示==、!=、<、<=、>、>=任何一个。

s1.begin()  返回指向s1第一个元素的迭代器。

s1.end()  返回指向s1最后一个元素的下一个位置的迭代器。

s1.empty()  表示s1容器是否为空,返回一个布尔值。

s1.size()  返回s1容器中元素的个数。

s1.swap(s2)  将s1容器和s2容器的内容交换。

STL分配器

参考资料:http://blog.csdn.net/md521/article/details/42046043

双层级配置器,第一级配置器直接使用malloc()和free(),第二级配置器则视情况采用不同的策略:当配置区块超过128bytes时,视之为“足够大”,便调用第一级配置器;当配置区小于128bytes时,视之为“过小”,为了降低额外负担,便采用复杂的memory pool 整理方式,而不再求助于第一级配置器。

未完待续~~~

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 203,324评论 5 476
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 85,303评论 2 381
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 150,192评论 0 337
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,555评论 1 273
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,569评论 5 365
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,566评论 1 281
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 37,927评论 3 395
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,583评论 0 257
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 40,827评论 1 297
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,590评论 2 320
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,669评论 1 329
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,365评论 4 318
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 38,941评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,928评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,159评论 1 259
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 42,880评论 2 349
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,399评论 2 342

推荐阅读更多精彩内容