- iOS/Objective-C 元类和类别
- objective-c - -1001 错误,当 NSURLSession 通过 httpproxy 和/etc/hosts
- java - 使用网络类获取 url 地址
- ios - 推送通知中不播放声音
我正在阅读 deque
s 与 vector
s,并遇到了它的 wikipedia entry ,表示 deque
的三种可能实现之一。使用动态数组是:
Allocating deque contents from the center of the underlying array, and resizing the underlying array when either end is reached. This approach may require more frequent resizings and waste more space, particularly when elements are only inserted at one end.
我想知道是否有任何实际使用这种中心分配策略的 STL(或 STL 风格)实现?
我问是因为这个策略看起来相当吸引人,因为它只涉及一个底层数组,因此消除了内存不连续问题,这可能是唯一的主要问题 deque
与vector
相比有.如果我理解正确的话,这很可能是 std::vector
的替代品。允许 O(1) pop_front
(摊销)或替换 deque
具有内存连续性保证。我假设这是以将 std::vector
的缓冲空间加倍为代价的,这不是我的用例的主要问题。
此外,在这样的容器中间插入/删除是否真的需要 std::vector
的一半时间?平均?
更新:
正如@Lightness Races in Orbit 指出的那样,在当前标准下不会使用这样的实现,因为没有人可以从每份与 STL 的契约(Contract)中获益,而每个人都会遭受不利影响。关于缺点,我还有一个问题是:
是否有可能实现新 vector
或 deque
像容器(比如 bivector
)这样除了 std::vector
的功能/操作符之外,
1) 提供(摊销)常数时间 push_front()
和 pop_front()
操作和
2) 保证内存连续性但在增长大小后不保证迭代器有效性?
我想象在幕后有一个数组,deque
上有很多间接/性能问题会消失。
最佳答案
没有标准库(不是“STL”)实现会为此烦恼,因为它有您提到的缺点,而优点不是 std::deque
要求的一部分。
这些要求是经过精心构建的,从各种操作的算法复杂性到迭代器失效规则。以没有人可以依赖该实现的优势的方式实现容器没有任何好处。
C++ 委员会能否在未来的标准中引入一个具有不同名称和不同约束的新容器,哪些供应商可以按照您的描述实现?是的,他们可以。
关于c++ - STL 实现中是否有中心分配双端队列或 vector ?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/24639573/
我有这个析构函数,它在运行时产生错误“vector 迭代器不可取消引用”。 gridMatrix 是一个 std::vector * > * > * > * > 我添加了 typename 和 typ
我有一个 vector 的 vector ,比方说 std::vector > my2dArray; 现在我想要一个 vector ,其中包含 my2dArray 中 vector 的大小。手动这看起
假设我有一些 vector :v1、v2、v3 假设我还有一个 vector 来保存这些 vList = {v1, v2, v3} 如果我同步了 (vList),这是否意味着 v1、v2 和 v3 也
我正在创建一个 char 的二维 vector 数组作为类变量,但我在将 vector 添加到 vector 数组中时遇到了麻烦。 我正在使用 C++ 11 标准运行 gcc。 我尝试使用 vecto
如何修改 Vec基于 Vec 中某项的信息没有对向量的不可变和可变引用? 我已尝试创建一个最小示例来演示我的特定问题。在我的真实代码中,Builder struct 已经是其他答案提出的中间结构。具体
这个问题在这里已经有了答案: What is the idiomatic Rust way to copy/clone a vector in a parameterized function? (
在我的程序中,我有一个整数 vector 的 vector 。现在我想从 vector 的 vector 中取出一个 vector 并在另一个 vector 容器中对其进行操作,但是我得到了错误...
我得到一个vector>数据由 OpenCV 提供。由于某些原因(例如偏移/缩放),我需要转换数据 Point至Point2f 。我怎样才能做到这一点? 例如: std::vector > conto
我有一个函数,该函数应使用来自字符串类型的给定 vector vector 中的某些元素初始化来自字符串类型的空 vector vector 。我的语法看起来像这样 std::vector> extr
我得到一个vector>数据由 OpenCV 提供。由于某些原因(例如偏移/缩放),我需要转换数据 Point至Point2f 。我怎样才能做到这一点? 例如: std::vector > conto
这里有很多类似的问题,但我没有真正找到任何可以特别回答我的问题的问题。 我有一个 vector 的 vector 作为类的属性。另一个属性是 bucket_count。我想将 vector 的 vec
如果我像这样创建一个 vector 的 vector : std::vector> myVectorOfVectors; 然后用一些东西填充它: std::vector myVector1; myVe
我正在用 C++ 编写自定义 vector 类。我对这样的代码有疑问: vector vec; vec.push_back(one); vec.push_back(two);
这是我发布的问题 c++ program for reading an unknown size csv file (filled only with floats) with constant (b
vector> a; for (int i=0;i v(i+1); iota(v.begin(),v.end(),1); a.push_back(v); } a.erase(a.beg
也许已经晚了,但我不明白为什么我会得到一个超出此代码范围的 vector 下标: int m = 3; int n = 2; std::vector> path(m, std::vector(n, 0
这个问题真的很奇怪,我似乎找不到任何导致它的原因。 所以这里有一个赋值运算符重载函数,鸟类和哺乳动物都是 vector 。 (下面是类) const Register& Register::opera
我怎么去 std::vector> 只是 std::vector> ?有真正有效的方法吗? 最佳答案 我会做这样的事情: #include #include int main() { //
我正在尝试将这些 vector 中的一些数据写入文本文件。当我运行代码时,它返回运行时错误。 Category、Product、Cart、Customer和Address都是struct 包含每个 g
显然它会因您使用的编译器而异,但我很好奇执行 vector> 时的性能问题与 vector*> ,尤其是在 C++ 中。具体来说: 假设您的外部 vector 已满,您想要开始将元素插入到第一个内部
我是一名优秀的程序员,十分优秀!