我很难弄清楚这一点。我的数据库(clients.txt)如下所示:
Tom;Test1;1000000.00;58010168302;63481000-10000090;1111;2000000.00;1000000.00
John;Test2;1000000.00;58010158125;63481000-10000091;2222;2000000.00;1000000.00
从左边开始:
name;surname;balance;pesel;cardNumber;pin;dailyLimit;maxDebit
我只有带有私有字段、getter、setter 和 DataBaseHandler 类的 DataBase 类,它读取 clients.txt 并制作我的 HashMap:
public static Map<Integer, DataBase> data = new HashMap<Integer, DataBase>();
private static Scanner scanner;
public static void read() {
try {
scanner = new Scanner(new FileReader("db/clients.txt"));
int i = 0;
while(scanner.hasNextLine()) {
String[] columnData = scanner.nextLine().split(";");
data.put(i, new DataBase(columnData[0],
columnData[1],
columnData[2],
columnData[3],
columnData[4],
columnData[5],
columnData[6],
columnData[7]));
i++;
}
这是客户端-服务器应用程序(ATM 模拟器),所以我在 ATMServer 类中调用 read() 函数,并在 ATMProtocol 类(扩展 DataBaseHandler)中操作(读取)该数据。我的问题在哪里?在制作支付功能。我想简单地更改余额的值或使用新的余额创建全新的行并删除旧的并将其保存到 clients.txt 文件中。我读过关于序列化的文章,所以我做了这个功能:
private String payment(String frameNum,
String cardNum,
String pinNum,
String amount) {
/* something less important
String answer = null;
double localAmount = Double.parseDouble(amount);
double newAmount = 0;
for(int i = 0; i < data.size(); i++) {
if(cardNum.equals(data.get(i).getCardNumber())
&& pinNum.equals(data.get(i).getPin())
&& checkAmount(localAmount, i)) {
newAmount = Double.parseDouble(data.get(i).getBalance()) - localAmount;
String newAmountString = String.valueOf(newAmount); */
DataBase dbBase = new DataBase(data.get(i).getName(),
data.get(i).getSurname(),
newAmountString,
data.get(i).getPesel(),
data.get(i).getCardNumber(),
data.get(i).getPin(),
data.get(i).getDailyLimit(),
data.get(i).getMaxDebit());
try {
FileOutputStream fileOut = new FileOutputStream("db/clients.txt",true);
ObjectOutputStream out = new ObjectOutputStream(fileOut);
out.writeObject(dbBase);
out.close();
fileOut.close();
} catch(IOException e) {
e.printStackTrace();
}
运行此应用程序之后,clients.txt 如下所示:
Tom;Test1;1000000.00;58010168302;63481000-10000090;1111;2000000.00;1000000.00
John;Test2;1000000.00;58010158125;63481000-10000091;2222;2000000.00;1000000.00
cardNumberq
dailyLimitq
2000000.00t
1000000.00t
最令人惊讶的是,当我复制最后四行并按 ctrl+v 时,它只会粘贴
cardNumberq
线。是不是编码有问题?如何解决我的问题?