5

我有一个 unique_ptrs 向量到使用基类的派生类型存储

std::unique_ptr<std::vector<std::unique_ptr<Variable>>> decisionVariables;

其中 Variable 是超类,派生类型是 Route 类。我的问题是当包含决策变量的类被删除时,路由实例似乎没有被删除。

Route 派生自变量:

#ifndef __VARIABLE__
#define __VARIABLE__

/**
 * Interface for decision variables. 
 */

#include <cstring>
#include <ostream>
#include <memory>

class Variable {

    public:
        /**
         * Returns an independent copy of this decision variable.
        *
        * @ret a copy of this decision variable
         */
        virtual std::unique_ptr<Variable> copy () = 0;

        virtual std::string toString () = 0;
};

#endif

路由的头文件:

#ifndef __ROUTE__
#define __ROUTE__

#include <vector>
#include <map>
#include <cstring>
#include <sstream>
#include <ostream>
#include <memory>
#include <set>
#include <algorithm>

#include "../../../Framework/h/core/Variable.h"

class Route : public Variable {

private:
    std::unique_ptr<std::vector<int>> route;
    double frequency;
    double routeLength;

public:
    Route ();
    void add (int);
    void addToFront (int);
    void remove ();
    void removeFromFront ();
    std::vector<int>::iterator begin();
    std::vector<int>::iterator end();
    int size ();
    std::vector<int> getViableNodes (std::shared_ptr<std::map<int, std::unique_ptr<std::vector<int>>>>, int);
    int front ();
    int back ();
    std::string toString ();
    int get (int);
    bool containsLink (int, int);
    bool contains (int);
    void replace (int, int);
    void setFrequency (double);
    double getFrequency ();

    void setRouteLength (double);
    double getRouteLength ();

    std::unique_ptr<Variable> copy ();
};

#endif

有没有办法防止目前经历的严重内存泄漏?

4

1 回答 1

8

您的抽象基类Variable没有虚拟析构函数,因此您不能使用指向该类的指针删除派生类的对象。这正是unique_ptr<Variable>它被摧毁时会尝试做的事情。

这将导致未定义的行为——最可能的行为是派生类的析构函数没有被调用,因此它管理的任何资源都会泄漏。

最简单的修复是基类中的虚拟析构函数:

virtual ~Variable() {}
于 2013-08-09T17:16:30.830 回答