how is push_back implemented in STL vector?(push_back 是如何在 STL 向量中实现的?)
问题描述
我在一次采访中被问到这个问题.
I was asked this question in an interview.
我回答的点是这样的
1) 指向当前位置的索引;
1) an index pointing to the current position;
2) 必要时调整大小.
2) resize if neccessary.
谁能说得详细点?
推荐答案
STL vector
有一个 size
(当前存储元素的数量)和一个 capacity
(当前分配的存储空间).
An STL vector
has a size
(current number of stored elements) and a capacity
(currently allocated storage space).
- 如果
size <容量
,push_back
只是将新元素放在最后,并将size
增加 1. - 如果
size == capacity
在push_back
之前,一个新的更大的数组被分配(两倍的大小是常见的,但这是依赖于实现的afaik),所有复制当前数据(包括新元素),并释放旧分配的空间.如果分配失败,这可能会引发异常.
- If
size < capacity
, apush_back
simply puts the new element at the end and increments thesize
by 1. - If
size == capacity
before thepush_back
, a new, larger array is allocated (twice the size is common, but this is implementation-dependent afaik), all of the current data is copied over (including the new element), and the old allocated space is freed. This may throw an exception if the allocation fails.
操作的复杂性摊销 O(1),这意味着在导致调整大小的push_back
期间,它不会是一个恒定时间的操作(但总的来说,在许多操作中,它是).
The complexity of the operation is amortized O(1), which means during a push_back
that causes a resize, it won't be a constant-time operation (but in general over many operations, it is).
这篇关于push_back 是如何在 STL 向量中实现的?的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持编程学习网!
本文标题为:push_back 是如何在 STL 向量中实现的?
基础教程推荐
- 从 std::cin 读取密码 2021-01-01
- 如何使图像调整大小以在 Qt 中缩放? 2021-01-01
- 如何在不破坏 vtbl 的情况下做相当于 memset(this, ...) 的操作? 2022-01-01
- Windows Media Foundation 录制音频 2021-01-01
- 在 C++ 中循环遍历所有 Lua 全局变量 2021-01-01
- 如何“在 Finder 中显示"或“在资源管理器中显 2021-01-01
- 使用从字符串中提取的参数调用函数 2022-01-01
- 管理共享内存应该分配多少内存?(助推) 2022-12-07
- 为 C/C++ 中的项目的 makefile 生成依赖项 2022-01-01
- 为什么语句不能出现在命名空间范围内? 2021-01-01