分段故障核心转储矢量指针

时间:2016-04-20 13:48:52

标签: c++ pointers segmentation-fault fault

void printTop5()
{
    int counter = 1;
    int x, y;
    float civ;
    cout << "Total no. of records available = " << pointVector.size();
    cout << "Printing top 5 exploration destinations....";
    sort(pointVector.begin(), pointVector.end(), ascendingCiv);
    for (int i = 0; i < 5; i++)
    {
        PointTwoD p1 = pointVector[i];
        x = p1.getX();
        y = p1.getY();
        civ = p1.getCivIndex();
        cout << counter << ")\t";
        if (civ > 0)
        {
            cout << "Civ idx: " << civ << " ; at sector(" << x << "," << y < ")\n";
        }
        else
            cout << "<No records available>";
    }
    }

bool ascendingCiv(const PointTwoD &d1, const PointTwoD &d2)
{
    return d1.getCivIndex() > d2.getCivIndex();
}

当我运行这个函数时,我得到了这个错误,它表示分段故障核心被丢弃。任何的想法?听说它有一些记忆问题。

1 个答案:

答案 0 :(得分:0)

一个问题是你没有检查你的向量中是否至少有5个元素:

for (int i = 0; i < 5; i++)
{
    PointTwoD p1 = pointVector[i];

如果i超出了向量的范围,则访问pointVector[i]会调用未定义的行为。

循环条件可以更改为以下内容:

#include <algorithm>
//...
size_t loopEnd = std::min(pointVector.size(), 5);
for (size_t i = 0; i < loopEnd; i++)
{
    PointTwoD p1 = pointVector[i];

循环将达到矢量大小或5个元素,以较小者为准。