如果你能帮助我理解为什么会出现下一个问题,我会很高兴:当我打印出我在列表中制作的所有部件时,它只打印出最后一个元素。如果你能告诉我为什么会这样,以及如何解决它,我会很高兴。
我的构造函数 -
BankAccount::BankAccount(std::string name)
: _name(std::move(name))
, _balance()
{ }
LimitedBankAccount::LimitedBankAccount(double limit, std::string name)
: BankAccount(std::move(name))
, _limit(limit)
,a(NULL)
{ }
// call to my Constructors
void LimitedBankAccount::NewLimitedBankAccount(double limit, std::string name)
{
this->a = new LimitedBankAccount(limit,name);
}
我的有限帐户.h -
#ifndef LIMITEDBANKACCOUNT_H
#define LIMITEDBANKACCOUNT_H
#include <iostream>
#include <string>
#include "BankAccount.h"
class LimitedBankAccount : public BankAccount{
public:
LimitedBankAccount(double limit, std::string _name);
void setLimit(double num);
double getLimit();
void NewLimitedBankAccount(double limit, std::string name);
void print();
private:
double _limit;
LimitedBankAccount* a;
};
#endif
打印功能 -
void LimitedBankAccount::print()
{
if(a != NULL)
{
this->a->print();
}
std::cout << this->_limit << std::endl;
}
感谢所有帮助者!!
答案 0 :(得分:0)
你忘了链接你的对象;每当你调用NewLimitedBankAccount()时,你都会覆盖this-&gt; a,丢失指向前一个对象的链接(所以你也会泄漏内存)。您应该将指针复制到新对象:
void LimitedBankAccount::NewLimitedBankAccount(double limit, std::string name)
{
NewLimitedBankAccount *na = new LimitedBankAccount(limit,name);
na->a = this->a;
this->a = na;
}
这实际上是链接列表101 ....是的,上面的内容适用于第一个分配的对象,当这个&gt; a最初为NULL时。