动态数组扩容通过调整容量平衡性能与内存,常见策略有倍增、线性及1.5倍增长,结合函数指针可灵活切换,提升特定场景下的效率表现。

在C++中,动态数组扩容是实现类似
std::vector
动态数组通常包含三个核心指针或变量:
当插入元素时,若
size == capacity
data
capacity
不同策略在内存使用和时间开销之间权衡:
立即学习“C++免费学习笔记(深入)”;
下面是一个支持自定义扩容策略的动态数组模板:
template<typename T>
class DynamicArray {
private:
T* data;
size_t size;
size_t cap;
<pre class='brush:php;toolbar:false;'>// 扩容策略函数指针
size_t (*growth_strategy)(size_t);
void reallocate() {
size_t new_cap = growth_strategy(cap);
T* new_data = new T[new_cap];
for (size_t i = 0; i < size; ++i) {
new_data[i] = std::move(data[i]);
}
delete[] data;
data = new_data;
cap = new_cap;
}public: explicit DynamicArray(size_t initial_cap = 10, size_t (*strategy)(size_t) = default_strategy) : data(new T[initial_cap]) , size(0) , cap(initial_cap) , growth_strategy(strategy) {}
~DynamicArray() {
delete[] data;
}
void push_back(const T& value) {
if (size == cap) reallocate();
data[size++] = value;
}
void push_back(T&& value) {
if (size == cap) reallocate();
data[size++] = std::move(value);
}
T& operator[](size_t index) { return data[index]; }
const T& operator[](size_t index) const { return data[index]; }
size_t length() const { return size; }
size_t capacity() const { return cap; }
// 默认策略:容量翻倍
static size_t default_strategy(size_t current) {
return current == 0 ? 1 : current * 2;
}
// 线性增长策略
static size_t linear_strategy(size_t current) {
return current + 10;
}
// 1.5倍增长策略
static size_t multiplicative_strategy(size_t current) {
return current == 0 ? 1 : current + (current >> 1); // current * 1.5
}};
根据应用场景选择合适的策略:
int main() {
// 使用默认翻倍策略
DynamicArray<int> arr1(8);
<pre class='brush:php;toolbar:false;'>// 使用1.5倍增长,减少内存浪费
DynamicArray<int> arr2(8, DynamicArray<int>::multiplicative_strategy);
// 使用线性增长,适用于小数据量且内存敏感场景
DynamicArray<int> arr3(8, DynamicArray<int>::linear_strategy);
for (int i = 0; i < 100; ++i) {
arr1.push_back(i);
}
return 0;}
选择策略时考虑:
基本上就这些。自定义扩容策略的关键在于平衡内存开销和复制成本,通过函数指针或模板参数灵活切换策略,能有效提升容器在特定场景下的表现。
以上就是C++动态数组扩容 自定义扩容策略实现的详细内容,更多请关注php中文网其它相关文章!
每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号