5

在尝试生成随机数向量时,我偶然发现了 std::bad_alloc 错误。这是我的代码:

#include "search.h"
#include "gtest/gtest.h"

int _size = 100;

std::vector<int> GetSortedVector(int size){
    //init vector
    std::vector<int> v(size);
    //fill with random numbers
    for (std::vector<int>::size_type i=0; i < v.size(); i++)
        v.push_back( std::rand()%(2*size) );
    //return the setup vector
    return v;
}

//triggered automatically
TEST(BinarySearch, NonUniqueSorted){
    std::vector<int> v = GetSortedVector(_size);//nothing moves farther than this line
}

PS:generate()现在确实在使用,但仍然很好奇为什么它失败了。

4

2 回答 2

8

v.push_back增加尺寸,所以i<v.size()从来没有false

由于您的矢量已经很size长,因此您需要用

for (std::vector<int>::size_type i=0; i < v.size(); i++)
    v[i] = std::rand()%(2*size);

reserve改用:

std::vector<int> v;
v.reserve(size);

保留push_back并检查size。我不会建议std::generate,因为你说你已经这样做了。

于 2013-01-22T20:43:19.110 回答
2

放大以下部分:

for (std::vector<int>::size_type i=0; i < v.size(); i++)
        v.push_back( std::rand()%(2*size) );

每次调用时push_back(),vector 的大小都会增加 1。因此,i < v.size()永远不会评估为 false,并且您的循环将继续进行,直到内存不足。修复它的一种可能方法是捕获size()一次,例如:

for (std::vector<int>::size_type i=0, s = v.size(); i < s; i++)
        v.push_back( std::rand()%(2*size) );
于 2013-01-22T20:43:41.873 回答