您好、欢迎来到现金彩票网!
当前位置:秒速快3平台 > 双向唯一性 >

C++ STL 容器 的 基本特性 和 原理

发布时间:2019-06-25 09:00 来源:未知 编辑:admin

  在末尾增加或删除元素所需时间与元素数目无关,在中间或开头增加或删除元素所需时间随元素数目呈线性变化。

  可动态增加或减少元素,内存管理自动完成,但程序员可以使用reserve()成员函数来管理内存。

  vector的迭代器在内存重新分配时将失效(它所指向的元素在该操作的前后不再相同)。当把超过capacity()-size()个元素插入vector中时,内存会重新分配,所有的迭代器都将失效;否则,指向当前元素以后的任何元素的迭代器都将失效。当删除元素时,指向被删除元素以后的任何元素的迭代器都将失效。

  在开头和末尾增加元素所需时间与元素数目无关,在中间增加或删除元素所需时间随元素数目呈线性变化。

  增加任何元素都将使deque的迭代器失效。在deque的中间删除元素将使迭代器失效。在deque的头或尾删除元素时,只有指向该元素的迭代器失效。

  增加任何元素都不会使迭代器失效。删除元素时,除了指向当前被删除元素的迭代器外,其它迭代器都不会失效。

  适配器,它可以将任意类型的序列容器转换为一个堆栈,一般使用deque作为支持的序列容器。

  适配器,它可以将任意类型的序列容器转换为一个队列,一般使用deque作为支持的序列容器。

  适配器,它可以将任意类型的序列容器转换为一个优先级队列,一般使用vector作为底层存储方式。

  按照键进行排序存储,值必须可以进行比较,可以理解为set就是键和值相等的map

  如果迭代器所指向的元素被删除,则该迭代器失效。其它任何增加、删除元素的操作都不会使迭代器失效。

  与set相比较,它里面的元素不一定是经过排序的,而是按照所用的hash函数分派的,它能提供更快的搜索速度(当然跟hash函数有关)。hash_set将key进行hash,然后将key放在hash值对应的桶中,原理可以这样理解,hash_set就是key,value相等的hash_map

  如果迭代器所指向的元素被删除,则该迭代器失效。其它任何增加、删除元素的操作都不会使迭代器失效。

  与map相比较,它里面的元素不一定是按键值排序的,而是按照所用的hash函数分派的,它能提供更快的搜索速度(当然也跟hash函数有关)。

http://raggedydreams.com/shuangxiangweiyixing/290.html
锟斤拷锟斤拷锟斤拷QQ微锟斤拷锟斤拷锟斤拷锟斤拷锟斤拷锟斤拷微锟斤拷
关于我们|联系我们|版权声明|网站地图|
Copyright © 2002-2019 现金彩票 版权所有