遇到此问题时,我正在测试一个有关分层继承的小程序。该程序包含一个父类的Bank和两个子类的取款和存款。
#include<iostream>
#include<conio.h>
#include<stdlib.h>
//Hierarchical Inheritance
using namespace std;
class bank{
protected:
char name[20];
int age, id;
float bal;
public:
void getData(){
cout <<"Enter your name, age, bank ID and balance" << endl;
cin >> name >> age >> id >> bal;
}
void display(){
cout <<"Name: " << name << endl << "ID: " << id << endl;
cout <<"Age: " << age <<endl <<"Balance: " << bal << endl;
}
void check(){
cout <<"Your balance is " << bal << endl;
}
};
class withdraw : public bank{
float wd;
public:
void withdrawMoney(){
cout << "Enter the amount to withdraw" << endl;
cin >> wd;
if(wd > bal)
cout << "You cannot withdraw that much. Your balance is only " << bal << endl;
else{
bal = bal-wd;
cout << "You successfully withdrew " << wd << ". Your remaining balance is " << bal << endl;
}
}
};
class deposit : public bank{
float dp;
public:
void depo(){
cout <<"Enter the amount to deposit" << endl;
cin >> dp;
bal = bal+dp;
cout <<"You successfully deposited " << dp << ". Your balance is now " << bal << "." << endl;
}
};
int main()
{
int c;
bank b;
deposit d;
withdraw w;
b.getData();
do{
cout <<"***The Dank Bank***" << endl;
cout <<"What do you want to do?\n 1)Withdraw\n 2)Deposit\n 3)Check Balance\n 4)Display all details\n 5)Exit\n" << endl;
cin >> c;
if(c == 1)
w.withdrawMoney();
else if (c == 2)
d.depo();
else if(c == 3)
b.check();
else if(c == 4)
b.display();
else if(c == 5)
exit(0);
else
cout <<"Wrong choice." << endl;
cout<<"Press any key to continue" << endl;
getch();
}
while(1);
getch();
return 0;
}
执行撤消功能时,我得到以下输出:
您不能撤出那么多钱。您的余额仅为6.03937e-039
使用存款功能时,输出将显示存款金额而不是实际余额。
您已成功存入1000。现在余额为1000。
两个子类都使用的唯一变量是bal,因此我决定像这样全局声明它。
#include<iostream>
#include<conio.h>
#include<stdlib.h>
float bal;
该程序没有任何缺陷。但是这样做会破坏使用继承的全部目的。
我糊涂了。为什么会这样呢?
最佳答案
类是对对象外观和行为的描述。你们三个一种描述您称为bank
的东西,一种描述为deposit
,另一种描述为withdraw
。
对象是类的实例。因此,对象是具有类应具有的存储和行为的对象。您有三个对象:b
,d
和w
。
每个对象都有其自己的独立存储。如果您希望某个对象知道另一个对象,则需要告诉它。 w
不能只找到b
。如果您有b_barclays
,b_natwest
和b_hsbc
怎么办?您希望w
找到哪个?为什么?
我认为您所做的是合并类,这些类告诉编译器如何使用对象本身创建对象。从另一个类继承的一个类仅表示子类将包括父类的行为和存储。因此,它说如果您创建两种类型的对象,则子代将具有父代能力的超集。它不会创建任何存储共享。每个都具有完全独立的存储,按类的定义进行布局。