一个vector必须存储两个size吗?
Does a vector have to store the size twice?
这是一个相当学术性的问题,我意识到它与优化无关,但这只是出于兴趣。
据我所知,当您调用new[size]
时,会分配额外的空间来存储已分配数组的大小。这样,当调用delete []
时,就知道可以释放多少空间。
我所做的是写下我认为向量将大致实现的方式:
#include <cstddef>
template <class T>
class Vector
{
public:
struct VectorStorage
{
std::size_t size;
T data[];
};
Vector(std::size_t size) : storage(new VectorStorage[size])
{
storage->size = size;
}
std::size_t size()
{
return storage->size;
}
~Vector()
{
delete[] storage;
}
private:
VectorStorage* storage;
};
据我所知,size
被存储了两次。一旦直接在VectorStorage
对象中(因为它需要这样size()
函数可以工作),但再次以编译器隐藏的方式,因此delete[]
可以工作。
似乎size
被存储了两次。这种情况是不可避免的吗?还是有办法确保大小只存储一次?
std::vector
不分配内存;std::allocator
,或者你给vector
的任何分配器,是分配内存的。分配器接口给出了要分配/释放的项数,因此不需要实际存储这些项数。
vector通常不存储大小。通常的实现在最后一个元素的末尾和分配的内存的末尾保持一个指针,因为可以在不实际存储元素的情况下reserve
空间。但是,没有标准的方法来访问new存储的大小(可能一开始就不存储),因此通常需要一些复制。
是。但这是堆分配器的实现细节,编译器对此一无所知。它几乎肯定与vector的容量不同,因为vector只关心元素的数量,而不是字节的数量。而且堆块往往有额外的开销。
你把size放在了错误的地方——你把它存储在每个元素中(通过一个VectorStorage数组),它还包含一个t的数组(每个VectorStorage实例)。你真的想在数组中有一个数组吗?你也不会在析构函数中清理T数组。
相关文章:
- 如何在C++中从两个单独的for循环中添加两个数组
- 为什么两个不同的未命名名称空间可以共存于一个cpp文件中
- 当在同一名称空间中有两个具有相同签名的函数时,会发生什么
- 如何返回一个类的两个对象相加的结果
- 如何在C++中将一个无符号的 int 转换为两个无符号的短裤?
- 如何将两个不同矢量的同一位置的两个元素组合在一起
- 两个字符串在 c++ 中不相等
- 在两个类中共享相同的函数调用,并在不需要时避免空实例化
- 两个文件使用彼此的功能-如何解决
- 为什么Mat类的两个对象可以在不重载运算符+的情况下添加
- 如何确保在使用基于布尔值的两个方法之一调用方法时避免分支预测错误
- 停止cmake target_link_libraries将插件中静态库的两个对象文件链接到静态库本身
- 将fold表达式与std::一起用于两个元组
- 如何在C++中比较两个char数组
- 给定两个偶数,求出它们之间所有偶数的平方和
- 比较两个大小不等的映射c++
- C++需要帮助从用户那里获得一个整数,并确保它在另外两个整数之间
- 如何在for循环中包含两个索引值的测试条件
- 在声明中合并两个常量"std::set"(不是在运行时)
- 一个vector必须存储两个size吗?