《达内培训内部》PPT课件.ppt
《《达内培训内部》PPT课件.ppt》由会员分享,可在线阅读,更多相关《《达内培训内部》PPT课件.ppt(17页珍藏版)》请在三一办公上搜索。
1、STL,STL,标准模板库(Standard Template Library)效率是STL设计的关键考虑因素STL包含很多最流行的数据结构,例如容器,并且提供了多种常用的算法来处理这些容器中的数据STL的三种关键组件容器迭代器算法类模板通常称为容器,函数模板都是通用算法类模板主要是对数据结构的设计函数模板主要是通用算法的设计,容器,标准容器序列容器关联式容器迭代器容器适配器(特殊容器),函数对象内存分配器,迭代器,迭代器在很多方面和指针类似,也是用于指向容器中的元素迭代器存有它们所指的容器的状态信息,即迭代器对每种类型的容器都有一个实现迭代器的本质是封装了的指针,支持+*-=!=运算,大部分
2、还支持-操作容器类基本都提供成员函数begin和end,begin函数返回一个指向容器中第一个元素的迭代器,end返回一个指向容器最后一个的下一个元素的迭代器STL中,通常用两个迭代器表示一个范围,这个范围是个半开半闭区间,标准容器,序列容器的共性vector deque list关联窗口的共性set multiset map multimap特殊容器(容器适配器)stack queue priority_queue,标准容器的共性,vector,deque,list,set/map,multi.构造函数:无参构造,拷贝构造,区间构造(两个迭代器表示的两个位置)析构迭代器相关:正向.begin
3、(),.end()反向.rbegin(),.rend()iterator,reverse_iterator,const_iterator,const_reverse_iterator*,-,=,+,=,!=-插入:.insert(pos,element),其中pos表示插入位置,是个迭代器,标准容器的共性,插入:.insert(pos,element),其中pos表示插入位置,是个迭代器删除:.erase(pos),.erase(pos_beg,pos_end)清除:.clear()大小:.size(),.max_size(),.empty()交换:.swap(c2),swap(c1,c2)成
4、员函数和非成员函数在使用时,优先考虑使用成员函数。运算符:=,=,=,=,!=另:标准库容器并没有严格检查错误,所以用错的后果是未知的。标准库容器共性举例。,序列式容器的共性,vector,deque,list序列式容器属于标准容器,所以具体标准容器所有的共性。除此之外,序列式有以下共性:构造函数:指定元素个数和初始值(初始值默认为零初始化)插入:.insert(pos,n,element),.insert(pos,pos_beg,pos_end)赋值:.assign(n,element),.assign(pos_beg,pos_end)调整:.resize(n,element=零初始化)首尾
5、:.front(),.back()注:返回的是首尾元素的引用增删:.push_back(element),.pop_back()只删除,返回void序列式容器共性举例。,序列式容器的个性介绍,vector.capacity();/取得当前分配了多少容量.reserve(n);/约定容量下标;/如同数组,支持下标操作,operator(i)即使越界也不检查.at(下标);/用下标访问,检查越界迭代器在使用时需要特别注意,在进行插入或删除后,之前获得的迭代器可能会失效。vector使用举例,deque,deque(double_ended_queue)由数组实现,支持下标操作,如vector.at
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- 达内培训内部 培训 内部 PPT 课件
链接地址:https://www.31ppt.com/p-5650523.html