后台: IBM ILOG Cplex的C ++接口非常规地分配和取消分配内存:
声明ILO环境IloEnv environment;
,然后在此环境中构建模型和求解器,然后所有这些对象(包括环境)超出范围会导致内存泄漏。请注意,我没有使用new
运算符。避免这种情况的一种方法是在对象超出范围之前调用environment.end();
。
设置:现在,我有一个类,其目的是解决特定的ILP。这个类有一些成员变量:
IloEnv ilpEnvironment_;
IloObjective ilpObjective_;
IloExpr ilpExpression_;
IloModel ilpModel_;
IloCplex ilpSolver_;
IloNumArray ilpSolution_;
IloNumVarArray ilpVariables_;
IloNumArray ilpStartValues_;
IloRangeArray constraints_;
这些成员变量在构造函数的初始化列表中初始化:
inline MyClass::MyClass()
: ilpEnvironment_(),
ilpObjective_(ilpEnvironment_),
ilpExpression_(ilpEnvironment_),
ilpModel_(ilpEnvironment_),
ilpSolver_(ilpModel_),
ilpSolution_(ilpEnvironment_),
ilpVariables_(ilpEnvironment_),
ilpStartValues_(ilpEnvironment_),
constraints_(ilpEnvironment_)
{ /* ... */ }
析构函数取消分配所有内存(已由对成员变量进行操作的类的成员函数分配):
inline MyClass::~MyClass() {
ilpEnvironment_.end();
}
问题:如何实现取消分配内存并将类重新置于其初始状态的成员函数void clear()
?以下是我做的两个相当天真的尝试:
inline void MyClass::clear() {
ilpEnvironment_.end();
ilpEnvironment_ = IloEnv(); // does not work, whether or not I comment this line out
ilpObjective_ = IloObjective(ilpEnvironment_);
ilpExpression_ = IloExpr(ilpEnvironment_);
ilpModel_ = IloModel(ilpEnvironment_);
ilpSolver_ = IloCplex(ilpEnvironment_);
ilpSolution_ = IloNumArray(ilpEnvironment_);
ilpVariables_ = IloNumVarArray(ilpEnvironment_);
ilpStartValues_ = IloNumArray(ilpEnvironment_);
constraints_ = IloRangeArray(ilpEnvironment_);
}
答案 0 :(得分:1)
如果类的目的是解决特定的ILP模型,那么我将使用模型大小/参数初始化类,并在solve()成员函数中创建和销毁CPLEX对象,同时仅将结果保存为班级成员。类成员将是模型参数,该对象将隐藏所有CPLEX交易。
你甚至可以有一个类成员来跟踪在特定的solve()调用中激活哪些约束。
如果您绝对 将CPLEX对象用作可更改的类成员,那么您可能希望尝试将对象指针用作类成员而不是对象本身。调用IloEnv :: end()会销毁与之关联的对象,因此可以调用IloEnd :: end()然后重新指定指向新对象的指针。