如何在std向量中推送数组

How to push an array in a std vector

本文关键字:数组 向量 std      更新时间:2023-10-16

我正在OpenGL中绘制一些高度图。每个顶点的唯一z存储在一个文件中,我还必须将x和y值存储在向量中:

#include <vector>
#include <fstream>
#include <sstream>
int main(void)
{
    std::vector<float>      _data;
    float constexpr         triangle_side(1.118033989);
    std::ifstream           ifs("mymap");
    std::string             line;
    if (not ifs.is_open())
        return -1;
    for (float y(0) ; std::getline(ifs, line) ; --y)
    {
        std::istringstream  iss(line);
        for (float x(static_cast<int>(y) % 2 ? 0 : triangle_side / 2), z ; iss >> z ; x += triangle_side)
            _data.push_back({x, y, z}); // does not compile
    }
    ifs.close();
    return 0;
}

在我看来,这样做是不好的:_data.push_back(x); _data.push_back(y); _data.push_back(z);,因为向量可能会在每次调用时重新分配数组。

最好的方法是什么?

如果我这样做:

std::vector< std::array<float, 3> > _data;
//...
_data.push_back({x, y, z});

是否保证所有值都是连续的?

std::array<float, 3>在内存中的布局类似于C数组,因此float s将是连续的。您也可以只使用insert:

_data.insert(_data.cend(), {x, y, z});

使用std::vector::reserve(size_type n)来保留后备数组至少包含n个元素。如果没有,它将被重新分配一次。在现有的向量上,如果您不仅需要"3"个元素,而且还需要"至少3个"元素,那么只需使用(std::vector::size+3)即可调用它。之后,您可以安全地向后推,并保证数组不会在向量内重新分配。

标准强制std::array的向量是连续的,std::vector也是如此。因此,std::数组的std::向量具有连续顺序的所有元素。源

@cin_cout:C++03(23.2.4.1):

向量的元素是连续存储的,这意味着如果v是一个向量,其中T是布尔以外的某种类型,则它服从身份&v[n]==&v[0]+n对于所有0<=n<v.尺寸().