Compare commits

..

No commits in common. "uebungNov8" and "main" have entirely different histories.

4 changed files with 29 additions and 67 deletions

View File

@ -73,10 +73,4 @@ public class Konto implements Serializable {
return saldo; return saldo;
} }
public void rollback() {
Kontobewegung kbw = kontobewegungen.get(kontobewegungen.size()-1);
stand += kbw.getBetrag() *-1;
kontobewegungen.remove(kontobewegungen.size()-1);
}
} }

View File

@ -1,6 +1,5 @@
package de.hs_mannheim.informatik.bank.facade; package de.hs_mannheim.informatik.bank.facade;
import java.io.IOException;
import java.util.Collection; import java.util.Collection;
import de.hs_mannheim.informatik.bank.domain.Bank; import de.hs_mannheim.informatik.bank.domain.Bank;
@ -11,23 +10,16 @@ import de.hs_mannheim.informatik.bank.infrastructure.Persistenz;
public class Banksystem { public class Banksystem {
private Bank bank; private Bank bank;
public Banksystem(String bankname) { public Banksystem(String bankname) throws Exception {
if (Persistenz.sindDatenGespeichert(bankname)) if (Persistenz.sindDatenGespeichert(bankname))
try { this.bank = (Bank) Persistenz.ladeBankDaten(bankname);
this.bank = (Bank) Persistenz.ladeBankDaten(bankname); else
this.bank = new Bank(bankname);
return;
} catch (ClassNotFoundException | IOException e) {
// Hier loggen wir die Exception und starten einfach mit einem leeren System.
System.err.println("Persistierte Daten konnten nicht geladen werden.");
}
this.bank = new Bank(bankname);
} }
public int kontoAnlegen(String name, int auswahl) throws IOException { public int kontoAnlegen(String name, int auswahl) throws Exception {
int kontonummer = bank.addKonto(name, auswahl); int kontonummer = bank.addKonto(name, auswahl);
Persistenz.speichereBankDaten(this.bank, bank.getName()); Persistenz.speichereBankDaten(this.bank, bank.getName());
return kontonummer; return kontonummer;
@ -49,27 +41,22 @@ public class Banksystem {
return bank.getName(); return bank.getName();
} }
public long geldEinzahlen(int kontonummer, long betrag) throws IOException { public long geldEinzahlen(int kontonummer, long betrag) throws Exception {
Konto konto = bank.findeKonto(kontonummer); Konto konto = bank.findeKonto(kontonummer);
konto.einzahlen(betrag, "Einzahlung am Schalter", "Einzahlung", konto.getInhaber()); konto.einzahlen(betrag, "Einzahlung am Schalter", "Einzahlung", konto.getInhaber());
try { Persistenz.speichereBankDaten(this.bank, bank.getName());
Persistenz.speichereBankDaten(this.bank, bank.getName());
} catch (IOException ioe) {
konto.rollback();
throw ioe;
}
return konto.getKontostand(); return konto.getKontostand();
} }
public boolean geldAuszahlen(int kontonummer, long betrag) throws IOException { public boolean geldAuszahlen(int kontonummer, long betrag) throws Exception {
Konto konto = bank.findeKonto(kontonummer); Konto konto = bank.findeKonto(kontonummer);
boolean erg = konto.auszahlen(betrag, "Auszahlung am Schalter", "Auszahlung", konto.getInhaber()); boolean erg = konto.auszahlen(betrag, "Auszahlung am Schalter", "Auszahlung", konto.getInhaber());
Persistenz.speichereBankDaten(this.bank, bank.getName()); Persistenz.speichereBankDaten(this.bank, bank.getName());
return erg; return erg;
} }
@ -86,7 +73,7 @@ public class Banksystem {
if (start instanceof Girokonto && ziel instanceof Girokonto) { if (start instanceof Girokonto && ziel instanceof Girokonto) {
boolean erfolg = ((Girokonto)start).überweise((Girokonto)ziel, betrag, verwendungszweck); boolean erfolg = ((Girokonto)start).überweise((Girokonto)ziel, betrag, verwendungszweck);
Persistenz.speichereBankDaten(this.bank, bank.getName()); Persistenz.speichereBankDaten(this.bank, bank.getName());
return erfolg; return erfolg;
} }
@ -101,7 +88,7 @@ public class Banksystem {
public long saldoBestimmen(int kontonummer, int anzahl) { public long saldoBestimmen(int kontonummer, int anzahl) {
Konto konto = bank.findeKonto(kontonummer); Konto konto = bank.findeKonto(kontonummer);
return konto.berechneSaldo(anzahl); return konto.berechneSaldo(anzahl);
} }

View File

@ -3,7 +3,6 @@ package de.hs_mannheim.informatik.bank.infrastructure;
import java.io.File; import java.io.File;
import java.io.FileInputStream; import java.io.FileInputStream;
import java.io.FileOutputStream; import java.io.FileOutputStream;
import java.io.IOException;
import java.io.ObjectInputStream; import java.io.ObjectInputStream;
import java.io.ObjectOutputStream; import java.io.ObjectOutputStream;
@ -14,13 +13,13 @@ public class Persistenz {
return new File(name + BANK_DATEI).exists(); return new File(name + BANK_DATEI).exists();
} }
public static void speichereBankDaten(Object bank, String name) throws IOException { public static void speichereBankDaten(Object bank, String name) throws Exception {
ObjectOutputStream oos = new ObjectOutputStream(new FileOutputStream(name + BANK_DATEI)); ObjectOutputStream oos = new ObjectOutputStream(new FileOutputStream(name + BANK_DATEI));
oos.writeObject(bank); oos.writeObject(bank);
oos.close(); oos.close();
} }
public static Object ladeBankDaten(String name) throws IOException, ClassNotFoundException { public static Object ladeBankDaten(String name) throws Exception {
ObjectInputStream ois = new ObjectInputStream(new FileInputStream(name + BANK_DATEI)); ObjectInputStream ois = new ObjectInputStream(new FileInputStream(name + BANK_DATEI));
Object bank = ois.readObject(); Object bank = ois.readObject();
ois.close(); ois.close();

View File

@ -1,6 +1,5 @@
package de.hs_mannheim.informatik.bank.ui; package de.hs_mannheim.informatik.bank.ui;
import java.io.IOException;
import java.util.Scanner; import java.util.Scanner;
import de.hs_mannheim.informatik.bank.facade.Banksystem; import de.hs_mannheim.informatik.bank.facade.Banksystem;
@ -50,6 +49,7 @@ public class UI {
case 7: saldoAbfragen(); break; case 7: saldoAbfragen(); break;
case 9: break mainloop; case 9: break mainloop;
} }
} catch (Exception e) { } catch (Exception e) {
System.err.println(e.getLocalizedMessage()); System.err.println(e.getLocalizedMessage());
} }
@ -72,7 +72,7 @@ public class UI {
} }
} }
private void kontoAnlegen() throws IOException { private void kontoAnlegen() throws Exception {
System.out.println("Bitte den Namen des Kontoinhabers angeben: "); System.out.println("Bitte den Namen des Kontoinhabers angeben: ");
String name = sc.nextLine(); String name = sc.nextLine();
@ -83,40 +83,22 @@ public class UI {
System.out.println("Konto mit der Nummer " + kontonummer + " neu angelegt."); System.out.println("Konto mit der Nummer " + kontonummer + " neu angelegt.");
} }
private void geldEinzahlen() throws IOException { private void geldEinzahlen() throws Exception {
int kontonummer = 0; System.out.println("Geld einzahlen");
double betrag = 0; System.out.print("Bitte die gewünschte Kontonummer eingeben: ");
boolean ok = false; int kontonummer = Integer.parseInt(sc.nextLine());
do { // optional prüfen, ob Konto existiert
System.out.println("Geld einzahlen");
System.out.print("Bitte die gewünschte Kontonummer eingeben: ");
try { System.out.print("Bitte den gewünschten Betrag eingeben: ");
kontonummer = Integer.parseInt(sc.nextLine()); double betrag = Double.parseDouble(sc.nextLine());
// optional prüfen, ob Konto existiert
} catch (NumberFormatException nfe) {
System.err.println("Kontonummer muss eine Zahl sein, bitte Eingabe wiederholen!");
continue;
}
System.out.print("Bitte den gewünschten Betrag eingeben: ");
try {
betrag = Double.parseDouble(sc.nextLine());
} catch (NumberFormatException nfe) {
System.err.println("Betrag muss eine Kommazahl sein, bitte Eingabe wiederholen!");
continue;
}
ok = true;
} while(!ok);
long neuerKontostand = bs.geldEinzahlen(kontonummer, (long)betrag * 100); long neuerKontostand = bs.geldEinzahlen(kontonummer, (long)betrag * 100);
System.out.printf("Einzahlung erfolgreich, neuer Kontostand = %.2f Euro", (neuerKontostand / 100.0)); System.out.printf("Einzahlung erfolgreich, neuer Kontostand = %.2f Euro", (neuerKontostand / 100.0));
} }
private void geldAuszahlen() throws IOException { private void geldAuszahlen() throws Exception {
System.out.println("Geld auszahlen"); System.out.println("Geld auszahlen");
System.out.print("Bitte die gewünschte Kontonummer eingeben: "); System.out.print("Bitte die gewünschte Kontonummer eingeben: ");
int kontonummer = Integer.parseInt(sc.nextLine()); int kontonummer = Integer.parseInt(sc.nextLine());
@ -163,14 +145,14 @@ public class UI {
System.out.println("Überweisung" + ( (!erfolgreich) ? " nicht" : "") + " erfolgreich ausgeführt."); System.out.println("Überweisung" + ( (!erfolgreich) ? " nicht" : "") + " erfolgreich ausgeführt.");
} }
private void saldoAbfragen() { private void saldoAbfragen() {
System.out.print("Bitte die Kontonummer des gewünschten Kontos eingeben: "); System.out.print("Bitte die Kontonummer des gewünschten Kontos eingeben: ");
int konto = Integer.parseInt(sc.nextLine()); int konto = Integer.parseInt(sc.nextLine());
System.out.print("Bitte die Anzahl der Kontobewegungen für den Saldo eingeben: "); System.out.print("Bitte die Anzahl der Kontobewegungen für den Saldo eingeben: ");
int anzahl = Integer.parseInt(sc.nextLine()); int anzahl = Integer.parseInt(sc.nextLine());
long saldo = bs.saldoBestimmen(konto, anzahl); long saldo = bs.saldoBestimmen(konto, anzahl);
System.out.printf("Der Saldo nach %d Kontobewegungen beträgt %.2f Euro.%n", anzahl, (saldo/100d)); System.out.printf("Der Saldo nach %d Kontobewegungen beträgt %.2f Euro.%n", anzahl, (saldo/100d));
} }