Условный оператор для проверки диапазона, предоставляемого #define(d) целыми числами в заголовке для модуля транзакции (.cpp)
Первое размещение на stackru. Я не уверен, что вопрос достаточно ясен, поэтому я постараюсь объяснить проблему и предоставить свой код.
Я предполагаю, что моя проблема - это проблема, связанная с условными операторами if, которые я создал в определении функций-членов, упомянутых в заголовке. В заголовке есть операторы #define, которые имеют целочисленные значения для MIN и MAX для целочисленных переменных, которые будут приняты из ввода пользователя. Кажется, я не могу проверить число по предоставленным данным. Я провел тест с контрольными значениями, выданными до и после условного утверждения, и они, кажется, проверяются независимо от того, что введено. У меня были все условия в одном заявлении if, если это что-то меняет.
Ниже приведен код для простого приложения учета, оно содержит модуль заголовка и транзакции (.cpp) и main.cpp:
// BTP200 Workshop 2: типы соединений и конфиденциальность MAIN.CPP
#include <iostream>
#include "AccountNumber.hpp"
using namespace std;
using namespace sict;
int main()
{
AccountNumber myNumber;
char name[41];
int bankCode;
int branchCode;
int accNumber;
cout << "Bank account app" << endl <<
"===================" << endl << endl;
cout << "Please enter your name: ";
cin >> name;
myNumber.setName(name);
cout << "please enter your bank account, branch code" <<
", and account number as follows:" << endl << "999 999 99999: ";
do
{
cin >> bankCode >> branchCode >> accNumber;
myNumber.setAccountNumber(bankCode, branchCode, accNumber);
myNumber.display();
} while(!myNumber.isValid() && cout << "Invalid account number, (999 999 99999), try again: ");
cout << "Thank you!" << endl;
return 0;
}
ACCOUNTNUMBER.CPP
#include <iostream>
#include <cstring>
#include "AccountNumber.hpp"
#define MAX_NAME_LENGTH 40
#define MIN_BANKCODE 100
#define MAX_BANKCODE 999
#define MIN_BRANCHCODE 1
#define MAX_BRANCHCODE 220
#define MIN_ACCNO 10000
#define MAX_ACCNO 99999
using namespace std;
namespace sict
{
void AccountNumber::setName(const char n[])
{
strcpy(name, n);
};
void AccountNumber::setAccountNumber(int bankc, int branchc, int an)
{
validAccNumber = false;
int bankc_v=0, branchc_v=0, an_v=0;
cout << bankc_v << branchc_v << an_v; //TESTING
if (bankc >= MIN_BANKCODE || bankc <= MAX_BANKCODE)
{
bankCode = bankc;
bankc_v=1;
}
else if (branchc >= MIN_BRANCHCODE || branchc <= MAX_BRANCHCODE)
{
branchCode = branchc;
branchc_v=1;
}
else if (an_v >= MIN_ACCNO || an_v <= MAX_ACCNO)
{
accountNumber = an;
an_v=1;
}
cout << bankc_v << branchc_v << an_v; //TESTING
else if(bankc_v==1 && branchc_v==1 && an_v==1)
{
validAccNumber = true;
}
}
void AccountNumber::display() const
{
if(isValid() == 1)
{
cout << "Name: " << name << ", Account number: " << bankCode << "-"
<< branchCode << "-" << accountNumber << endl;
}
else
{
cout << name << " does not have a valid account number." << endl;
}
}
bool AccountNumber::isValid() const
{
return AccountNumber::validAccNumber;
}
}
ACCOUNTNUMBER.HPP
#ifndef AccountNumber_hpp
#define AccountNumber_hpp
#include <stdio.h>
#define MAX_NAME_LENGTH 40
#define MIN_BANKCODE 100
#define MAX_BANKCODE 999
#define MIN_BRANCHCODE 1
#define MAX_BRANCHCODE 220
#define MIN_ACCNO 10000
#define MAX_ACCNO 99999
namespace sict
{
class AccountNumber
{
char name[MAX_NAME_LENGTH + 1];
int bankCode;
int branchCode;
int accountNumber;
bool validAccNumber;
public:
void setName(const char n[]);
void setAccountNumber(int bankc, int branchc, int an);
void display() const;
bool isValid() const;
};
}
#endif /* AccountNumber_hpp */
*** ОБНОВЛЕНО ****
// BTP200 Workshop 2: типы соединений и конфиденциальность MAIN.CPP
#include <iostream>
#include "AccountNumber.hpp"
using namespace std;
using namespace sict;
int main()
{
AccountNumber myNumber;
char name[41];
int bankCode;
int branchCode;
int accNumber;
cout << "Bank account app" << endl <<
"===================" << endl << endl;
cout << "Please enter your name: ";
cin >> name;
myNumber.setName(name);
cout << "please enter your bank account, branch code" <<
", and account number as follows:" << endl << "999 999 99999: ";
do
{
cin >> bankCode >> branchCode >> accNumber;
myNumber.setAccountNumber(bankCode, branchCode, accNumber);
myNumber.display();
} while(!myNumber.isValid() && cout << "Invalid account number, (999 999 99999), try again: ");
cout << "Thank you!" << endl;
return 0;
}
ACCOUNTNUMBER.CPP
#include <iostream>
#include <cstring>
#include "AccountNumber.hpp"
#define MAX_NAME_LENGTH 40
#define MIN_BANKCODE 100
#define MAX_BANKCODE 999
#define MIN_BRANCHCODE 1
#define MAX_BRANCHCODE 220
#define MIN_ACCNO 10000
#define MAX_ACCNO 99999
using namespace std;
namespace sict
{
void AccountNumber::setName(const char n[])
{
strcpy(name, n);
};
void AccountNumber::setAccountNumber(int bankc, int branchc, int an)
{
validAccNumber = false;
int bankc_v=0, branchc_v=0, an_v=0;
cout << bankc_v << branchc_v << an_v;
if (bankc >= MIN_BANKCODE && bankc <= MAX_BANKCODE)
{
bankCode = bankc;
bankc_v=1;
}
if (branchc >= MIN_BRANCHCODE && branchc <= MAX_BRANCHCODE)
{
branchCode = branchc;
branchc_v=1;
}
if (an_v >= MIN_ACCNO && an_v <= MAX_ACCNO)
{
accountNumber = an;
an_v=1;
}
cout << bankc_v << branchc_v << an_v;
if(bankc_v==1 && branchc_v==1 && an_v==1)
{
validAccNumber = true;
}
}
void AccountNumber::display() const
{
if(isValid() == 1)
{
cout << "Name: " << name << ", Account number: " << bankCode << "-"
<< branchCode << "-" << accountNumber << endl;
}
else
{
cout << name << " does not have a valid account number." << endl;
}
}
bool AccountNumber::isValid() const
{
return AccountNumber::validAccNumber;
}
}
ACCOUNTNUMBER.HPP
#ifndef AccountNumber_hpp
#define AccountNumber_hpp
#include <stdio.h>
#define MAX_NAME_LENGTH 40
#define MIN_BANKCODE 100
#define MAX_BANKCODE 999
#define MIN_BRANCHCODE 1
#define MAX_BRANCHCODE 220
#define MIN_ACCNO 10000
#define MAX_ACCNO 99999
namespace sict
{
class AccountNumber
{
char name[MAX_NAME_LENGTH + 1];
int bankCode;
int branchCode;
int accountNumber;
bool validAccNumber;
public:
void setName(const char n[]);
void setAccountNumber(int bankc, int branchc, int an);
void display() const;
bool isValid() const;
};
}
#endif /* AccountNumber_hpp */
ВЫХОД:
Bank account app
===================
Please enter your name: John
please enter your bank account, branch code, and account number as follows:
999 999 99999: 1 123 12345
000010John does not have a valid account number.
Invalid account number, (999 999 99999), try again: 1234 123 12345
000010John does not have a valid account number.
Invalid account number, (999 999 99999), try again: 123 0 12345
000100John does not have a valid account number.
Invalid account number, (999 999 99999), try again: 123 1234 12345
000100John does not have a valid account number.
Invalid account number, (999 999 99999), try again: 123 123 123
000110John does not have a valid account number.
Invalid account number, (999 999 99999), try again: 123 123 123456
000110John does not have a valid account number.
Invalid account number, (999 999 99999), try again: 123 123 12345
000110John does not have a valid account number.
Invalid account number, (999 999 99999), try again: 123 12345
123
000100John does not have a valid account number.
Invalid account number, (999 999 99999), try again: 123 123 12345
000110John does not have a valid account number.
Invalid account number, (999 999 99999), try again: 123 123
123
000110John does not have a valid account number.
Invalid account number, (999 999 99999), try again:
2 ответа
Это
else if (an_v >= MIN_ACCNO || an_v <= MAX_ACCNO)
должно быть
if (an >= MIN_ACCNO && an <= MAX_ACCNO)
Ваши операторы if всегда оцениваются как истина. Например, взгляните на один из них:
if (bankc >= MIN_BANKCODE || bankc <= MAX_BANKCODE)
В этом утверждении, потому что вы используете '||' оператор, вы в основном проверяете, верно ли только одно из логических подвыражений. Однако для проверки ваших чисел необходимо, чтобы оба логических подвыражения были истинными.
Вместо этого то, что вы, вероятно, хотите, это:
if (bankc >= MIN_BANKCODE && bankc <= MAX_BANKCODE)
Использование '&&' гарантирует, что оба ваших логических подвыражения будут проверены.