gpt4 book ai didi

c++ - 当我离开该方法时,来自静态 vector 的数据保持不变

转载 作者:行者123 更新时间:2023-11-28 05:32:37 26 4
gpt4 key购买 nike

这是我在学习 C++ 时想到的一个 Bank 项目,我在我学习继承和指针时一直在添加它。这用户是可以创建新客户或流程的银行出纳员现有客户的交易。

A CustomerSavingsChecking类作为继承的私有(private)字段来自 Account . Bank类从其私有(private) static vector<Customer> 添加/获取客户 field 。

意想不到的结果是,在“process_transaction”方法中我可以获取vector 中的客户并从其帐户中存款/取款,但是一旦我离开该方法并返回到它,帐户数据从我初始化它们时就没有改变。

需要帮助。这是客户问题的引用?我应该什么时候回来引用还是指针?

这是代码。在驱动程序类中,我有一个创建客户的方法

/*
* Create customer from teller input then add the Customer
* to Bank's private static vector<Customer> field.
*/
int create_customer(){
cout << "** Create New Customer **\n";
cout << "Customer Name: ";
string n = "";
cin >> n;
Customer* d = new Customer(n, gen_acct_number());
Customer c(*d);
// get opening balances
double open_ck = 0;
double open_sv = 0;
cout << "Opening Balance For Checking: ";
cin >> open_ck;

cout << "Opening Balance For Savings: ";
cin >> open_sv;
cout << "\n";

// create and set accounts
Checking ck(open_ck);
Savings sv(open_sv);
c.set_checking(ck);
c.set_savings(sv);

// add customer to bank
Bank b;
b.add_customer(c);
cout << "New Customer: " << c.get_name() << endl;
cout << "Account Number: " << c.get_acct_number() << endl;
cout << "\n";
return 0;

}

我在驱动程序类中有另一个方法来处理客户。有一次,我保留此方法,客户的帐户保持不变,但以其他方式工作。

/*
* Fetch customer by account number from Bank's private static
* vector<Customer> and perform transactions on Customer's accounts
* until teller has finished processing the customer.
*/
int process_customer(){
cout << "** Process Transaction **\n";
cout << "Account Number: ";
int acctNum = 0;
cin >> acctNum;
cout << "\n";

// get customer
Bank b;
Customer c = b.get_customer(acctNum);

//if(c* == NULL){
// cout << "Error: Customer Not Found.\n";
// return 0;
//}

bool flag = true;
while(flag){
cout << c.get_name() << " #" << c.get_acct_number() << ": ";

cout << "Select a transaction.\n";
cout << "1. Withdrawl\n";
cout << "2. Deposit\n";
cout << "3. Check Balance\n";
cout << "4. Quit\n";
cout << "> ";
int choice = 0;
cin >> choice;
cout << "\n";

double amt = 0;
int which = 0;
switch(choice){
case 1:{ // WITHDRAWL

cout << "Withdrawl From: \n";
cout << "1. Checking \n2. Savings \n";
cout << "> ";
cin >> which;
cout << "\n";
cout << "Amount: ";
cin >> amt;
cout << "\n";

if(which == 1){
cout << "Old Balance: " << c.get_checking().get_balance() << endl;
c.get_checking().withdrawl(amt);
cout << "New Balance: " << c.get_checking().get_balance() << endl;
cout << "\n";
}else if (which == 2){
cout << "Old Balance: " << c.get_savings().get_balance() << endl;
c.get_savings().withdrawl(amt);
cout << "New Balance: " << c.get_savings().get_balance() << endl;
cout << "\n";
}else{
break;
}
break;
}
case 2:{ // DEPOSIT

cout << "Deposit Into: \n";
cout << "1. Checking \n2. Savings \n";
cout << "> ";
cin >> which;
cout << "\n";

cout << "Amount: ";
cin >> amt;
cout << "\n";
if(which == 1){
cout << "Old Balance: " << c.get_checking().get_balance() << endl;
c.get_checking().deposit(amt);
cout << "New Balance: " << c.get_checking().get_balance() << endl;
cout << "\n";

}else if (which == 2){
cout << "Old Balance: " << c.get_savings().get_balance() << endl;
c.get_savings().deposit(amt);
cout << "New Balance: " << c.get_savings().get_balance() << endl;
cout << "\n";
}else{
break;
}
break;
}
case 3:{ // CHECK BALANCE

cout << "Checking " << c.get_checking().get_balance() << endl;
cout << "Savings " << c.get_savings().get_balance() << endl;
cout << "\n";
break;
}
default:{ // EXIT

flag = false;
break;
}
}
}

return 0;
}

银行类。

Bank::Bank(){}

Customer& Bank::get_customer(int acct_number) {

for(unsigned i = 0; i < cus.size(); i++){
if(cus[i].get_acct_number() == acct_number){
return cus[i];
}
}
return cus[0];
}
void Bank::add_customer(Customer c){
cus.push_back(c);
}

/* Disabled. I want to pass an account to these methods.
*
* void Bank::deposit(double amt, Account& a){
* a.deposit(amt);
* }
* void Bank::withdrawl(double amt, Account& a){
* a.withdrawl(amt);
* }
* double Bank::check_balance( Account& a){
* return a.get_balance();
* }
*/


vector<Customer> Bank::cus;

Bank.h

#ifndef BANK_H_
#define BANK_H_


#include "../include/Customer.h"
#include <string>
#include <vector>
using namespace std;

class Bank{

public:
Bank();
Customer& get_customer(int acct_number);
void add_customer(Customer c);
void deposit(double amt, Account& a);
void withdrawl(double amt, Account& a);
double check_balance( Account& a);
private:
static vector<Customer> cus;
};



#endif /* BANK_H_ */

最佳答案

这确实是一个引用问题。在您的 process_customer 函数中,更改:

// get customer
Bank b;
Customer c = b.get_customer(acctNum);

到:

// get customer
Bank b;
Customer& c = b.get_customer(acctNum);

如果不进行此更改,您将制作客户的拷贝,然后修改此拷贝,而不是修改原始客户。

关于c++ - 当我离开该方法时,来自静态 vector 的数据保持不变,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/39103334/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com