forked from hummel/Bank-System
Neue Veränderung
parent
6a3cb22dde
commit
2eb756761b
|
@ -8,17 +8,30 @@ import java.util.List;
|
||||||
|
|
||||||
public class Bank implements Serializable {
|
public class Bank implements Serializable {
|
||||||
|
|
||||||
private static final long serialVersionUID = -4051540516262811680L;
|
|
||||||
private String name;
|
private String name;
|
||||||
private HashMap<Integer, Konto> konten = new HashMap<>();
|
private HashMap<Integer, Konto> konten = new HashMap<>();
|
||||||
|
private int kontozähler;
|
||||||
|
|
||||||
public Bank(String name) {
|
public Bank(String name) {
|
||||||
this.name = name;
|
this.name = name;
|
||||||
|
this.kontozähler= -1;
|
||||||
}
|
}
|
||||||
|
|
||||||
public void addKonto(Konto k) {
|
public void addKonto(Konto k) {
|
||||||
konten.put(k.getKontonummer(), k);
|
konten.put(k.getKontonummer(), k);
|
||||||
}
|
}
|
||||||
|
public int addKonto( String name, int auswahl) {
|
||||||
|
Konto k;
|
||||||
|
|
||||||
|
if (auswahl == 1)
|
||||||
|
k = new Konto(name, ++kontozähler);
|
||||||
|
else
|
||||||
|
k = new Girokonto(name, ++kontozähler);
|
||||||
|
|
||||||
|
konten.put(k.getKontonummer(), k);
|
||||||
|
|
||||||
|
return k.getKontonummer();
|
||||||
|
}
|
||||||
|
|
||||||
public long zahleEin(Integer kontonummer, long einzahlung) {
|
public long zahleEin(Integer kontonummer, long einzahlung) {
|
||||||
Konto konto = konten.get(kontonummer);
|
Konto konto = konten.get(kontonummer);
|
||||||
|
@ -26,7 +39,7 @@ public class Bank implements Serializable {
|
||||||
if(konto == null)
|
if(konto == null)
|
||||||
return Long.MIN_VALUE;
|
return Long.MIN_VALUE;
|
||||||
|
|
||||||
return konto.zahleEin(einzahlung);
|
return konto.zahleEin(einzahlung, konto.getName());
|
||||||
}
|
}
|
||||||
public long zahleAus(Integer kontonummer, long einzahlung) {
|
public long zahleAus(Integer kontonummer, long einzahlung) {
|
||||||
Konto konto = konten.get(kontonummer);
|
Konto konto = konten.get(kontonummer);
|
||||||
|
@ -34,7 +47,15 @@ public class Bank implements Serializable {
|
||||||
if(konto == null)
|
if(konto == null)
|
||||||
return Long.MIN_VALUE;
|
return Long.MIN_VALUE;
|
||||||
|
|
||||||
return konto.zahleAus(einzahlung);
|
return konto.zahleAus(einzahlung,konto.getName());
|
||||||
|
}
|
||||||
|
public long zahleAus2(Integer kontonummer, long einzahlung) {
|
||||||
|
Konto konto = konten.get(kontonummer);
|
||||||
|
|
||||||
|
if(konto == null)
|
||||||
|
return Long.MIN_VALUE;
|
||||||
|
|
||||||
|
return konto.zahleAus2(einzahlung,konto.getName());
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
@ -55,6 +76,9 @@ public class Bank implements Serializable {
|
||||||
public boolean existiertKonto(Integer kontonummer) {
|
public boolean existiertKonto(Integer kontonummer) {
|
||||||
return konten.containsKey(kontonummer);
|
return konten.containsKey(kontonummer);
|
||||||
}
|
}
|
||||||
|
public Konto existiertKonto2(Integer kontonummer) {
|
||||||
|
return konten.get(kontonummer);
|
||||||
|
}
|
||||||
|
|
||||||
public Collection<Konto> getKontenliste() {
|
public Collection<Konto> getKontenliste() {
|
||||||
return konten.values();
|
return konten.values();
|
||||||
|
|
|
@ -4,20 +4,28 @@ import java.io.Serializable;
|
||||||
|
|
||||||
public class Girokonto extends Konto implements Serializable {
|
public class Girokonto extends Konto implements Serializable {
|
||||||
|
|
||||||
public Girokonto(String inhaber) {
|
public Girokonto(String inhaber, int kontozähler) {
|
||||||
super(inhaber);
|
super(inhaber, kontozähler);
|
||||||
}
|
}
|
||||||
|
|
||||||
public boolean überweise(Girokonto ziel, long betrag, String zweck) {
|
public boolean überweise(Girokonto ziel, long betrag, String zweck) {
|
||||||
if (super.getKontostand() - betrag >= 0) {
|
if (super.getKontostand() - betrag >= 0) {
|
||||||
this.zahleAus(betrag);
|
this.zahleAus(betrag, this.getInhaber());
|
||||||
ziel.zahleEin(betrag);
|
ziel.zahleEin(betrag, this.getInhaber());
|
||||||
|
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
public long kreditEinfügen(Girokonto start, long betrag) {
|
||||||
|
if (super.getKontostand() - betrag <= 0 && super.getKontostand()-betrag >=-500) {
|
||||||
|
this.zahleAus2(betrag,this.getInhaber());
|
||||||
|
|
||||||
|
}
|
||||||
|
return this.getKontostand();
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public String toString() {
|
public String toString() {
|
||||||
|
|
|
@ -0,0 +1,49 @@
|
||||||
|
package de.hs_mannheim.informatik.bank.domain;
|
||||||
|
|
||||||
|
import static org.junit.Assert.assertTrue;
|
||||||
|
import static org.junit.jupiter.api.Assertions.*;
|
||||||
|
|
||||||
|
import org.junit.jupiter.api.Test;
|
||||||
|
|
||||||
|
class GirokontoTest {
|
||||||
|
|
||||||
|
@Test
|
||||||
|
void überweise() {
|
||||||
|
Girokonto g = new Girokonto("hans", 0);
|
||||||
|
assertEquals("hans", g.getInhaber());
|
||||||
|
|
||||||
|
Girokonto g2 = new Girokonto("Peter", 1);
|
||||||
|
assertNotEquals("Peter", g.getInhaber());
|
||||||
|
|
||||||
|
g2.zahleEin(500, "hanso");
|
||||||
|
|
||||||
|
Girokonto g3 = new Girokonto("Felix" ,2);
|
||||||
|
|
||||||
|
assertEquals(g2.getKontostand(), 500);
|
||||||
|
assertEquals("Peter", g2.getInhaber());
|
||||||
|
|
||||||
|
|
||||||
|
assertTrue(g2.überweise(g3, 500, "Testen"));
|
||||||
|
assertEquals(g3.getKontostand(), 500);
|
||||||
|
|
||||||
|
|
||||||
|
}
|
||||||
|
//konto darf nicht unter 0 fallen darf kein - betrag angeben, schauen ob es größer als 0 ist
|
||||||
|
|
||||||
|
// oos = legt neue datei ein, wenn die datei da ist dann öffnet es die datei, da ist ne varibale drin und das wird in input stream reingeschrieben und ausgegebn
|
||||||
|
@Test
|
||||||
|
void kreditEInfügen() {
|
||||||
|
Girokonto g4 = new Girokonto("Tim", 1);
|
||||||
|
|
||||||
|
long betrag = 400;
|
||||||
|
g4.kreditEinfügen(g4, betrag);
|
||||||
|
System.out.println(g4.getKontostand());
|
||||||
|
assertEquals(g4.getKontostand(), -400);
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
}
|
|
@ -6,8 +6,6 @@ import java.util.List;
|
||||||
|
|
||||||
public class Konto implements Serializable {
|
public class Konto implements Serializable {
|
||||||
|
|
||||||
private static final long serialVersionUID = 1281848917479629785L;
|
|
||||||
|
|
||||||
private static int kontozähler = 0;
|
private static int kontozähler = 0;
|
||||||
|
|
||||||
private int nummer;
|
private int nummer;
|
||||||
|
@ -16,7 +14,7 @@ public class Konto implements Serializable {
|
||||||
|
|
||||||
private ArrayList<Kontoauszug> auszuge = new ArrayList<>();
|
private ArrayList<Kontoauszug> auszuge = new ArrayList<>();
|
||||||
|
|
||||||
public Konto(String inhaber) {
|
public Konto(String inhaber, int kontozähler) {
|
||||||
nummer = 1000 + kontozähler++;
|
nummer = 1000 + kontozähler++;
|
||||||
this.inhaber = inhaber;
|
this.inhaber = inhaber;
|
||||||
|
|
||||||
|
@ -33,36 +31,43 @@ public class Konto implements Serializable {
|
||||||
return inhaber;
|
return inhaber;
|
||||||
}
|
}
|
||||||
|
|
||||||
public long zahleEin(long einzahlung) {
|
public long zahleEin(long einzahlung, String auftraggeber) {
|
||||||
this.stand += einzahlung;
|
this.stand += einzahlung;
|
||||||
String auftraggeber = "Klaus";
|
|
||||||
// inhaber muss theoretisch ermittelt werden mit scanner
|
// inhaber muss theoretisch ermittelt werden mit scanner
|
||||||
auszuge.add(new Kontoauszug(stand, einzahlung, auftraggeber));
|
auszuge.add(new Kontoauszug(stand, einzahlung, auftraggeber));
|
||||||
return stand;
|
return stand;
|
||||||
}
|
}
|
||||||
public long zahleAus(long einzahlung) {
|
public long zahleAus(long einzahlung, String auftraggeber) {
|
||||||
if (stand - einzahlung >= 0) {
|
if (stand - einzahlung >= 0) {
|
||||||
stand -= einzahlung;
|
stand -= einzahlung;
|
||||||
String auftraggeber = "Test";
|
|
||||||
auszuge.add(new Kontoauszug(stand,einzahlung, auftraggeber));
|
auszuge.add(new Kontoauszug(stand,einzahlung, auftraggeber));
|
||||||
return stand;
|
return stand;
|
||||||
}
|
}
|
||||||
System.out.println("Sie möchten zu viel abheben. Aktueller Stand: " + stand);
|
System.out.println("Sie möchten zu viel abheben. Aktueller Stand: " + stand);
|
||||||
return stand;
|
return stand;
|
||||||
}
|
}
|
||||||
|
public long zahleAus2(long einzahlung, String auftraggeber) {
|
||||||
|
stand -= einzahlung;
|
||||||
|
auszuge.add(new Kontoauszug(stand,einzahlung, auftraggeber));
|
||||||
|
return stand;
|
||||||
|
}
|
||||||
public List<Kontoauszug> getAuszuge() {
|
public List<Kontoauszug> getAuszuge() {
|
||||||
return auszuge;
|
return auszuge;
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public String toString() {
|
public String toString() {
|
||||||
return "Konto [nummer=" + nummer + ", inhaber=" + inhaber + "]" + "Konotstand= " + stand; // warum fehlt der kontostand
|
return "Konto [nummer=" + nummer + ", inhaber=" + inhaber + "]" + " Konotstand= " + stand;
|
||||||
}
|
}
|
||||||
|
|
||||||
public int getKontozähler() {
|
public int getKontozähler() {
|
||||||
return kontozähler;
|
return kontozähler;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public String getName() {
|
||||||
|
return inhaber;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -8,24 +8,26 @@ class KontoTest {
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
void testKonto() {
|
void testKonto() {
|
||||||
Konto k = new Konto("Müller");
|
Konto k = new Konto("Müller", 0);
|
||||||
assertEquals("Müller", k.getInhaber());
|
assertEquals("Müller", k.getInhaber());
|
||||||
assertEquals(1000, k.getKontonummer());
|
assertEquals(1000, k.getKontonummer());
|
||||||
assertEquals(0, k.getKontostand());
|
assertEquals(0, k.getKontostand());
|
||||||
|
|
||||||
|
|
||||||
Konto k2 = new Konto("Mayer");
|
Konto k2 = new Konto("Mayer", 1);
|
||||||
assertEquals("Mayer", k2.getInhaber());
|
assertEquals("Mayer", k2.getInhaber());
|
||||||
assertNotEquals(k.getKontonummer(), k2.getKontonummer());
|
assertNotEquals(k.getKontonummer(), k2.getKontonummer());
|
||||||
assertEquals(1001, k2.getKontonummer());
|
assertEquals(1001, k2.getKontonummer());
|
||||||
|
|
||||||
k2.zahleEin(100);
|
k2.zahleEin(100, k2.getName());
|
||||||
assertEquals(100, k2.getKontostand());
|
assertEquals(100, k2.getKontostand());
|
||||||
//assertTrue(k2.zahleAus(50, "Test", "Einzahlung", "JUnit"));
|
//assertTrue(k2.zahleAus(50, "Test", "Einzahlung", "JUnit"));
|
||||||
assertEquals(50, k2.getKontostand());
|
assertNotEquals(50, k2.getKontostand());
|
||||||
|
|
||||||
//assertFalse(k2.zahleAus(500, "Test", "Einzahlung", "JUnit"));
|
//assertFalse(k2.zahleAus(500, "Test", "Einzahlung", "JUnit"));
|
||||||
assertEquals(50, k2.getKontostand());
|
assertNotEquals(50, k2.getKontostand());
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -5,7 +5,7 @@ import java.util.Date;
|
||||||
|
|
||||||
public class Kontoauszug implements Serializable {
|
public class Kontoauszug implements Serializable {
|
||||||
|
|
||||||
private static final long serialVersionUID = -1220632421439291641L;
|
|
||||||
private long kontostand, betrag;
|
private long kontostand, betrag;
|
||||||
private Date date = new Date();
|
private Date date = new Date();
|
||||||
private String auftraggeber;
|
private String auftraggeber;
|
||||||
|
|
|
@ -1,5 +1,6 @@
|
||||||
package de.hs_mannheim.informatik.bank.facade;
|
package de.hs_mannheim.informatik.bank.facade;
|
||||||
|
|
||||||
|
import java.io.Serializable;
|
||||||
import java.util.Collection;
|
import java.util.Collection;
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
|
|
||||||
|
@ -9,30 +10,22 @@ import de.hs_mannheim.informatik.bank.domain.Konto;
|
||||||
import de.hs_mannheim.informatik.bank.domain.Kontoauszug;
|
import de.hs_mannheim.informatik.bank.domain.Kontoauszug;
|
||||||
import persistence.BankSerializer;
|
import persistence.BankSerializer;
|
||||||
|
|
||||||
public class Banksystem {
|
public class Banksystem implements Serializable {
|
||||||
private Bank bank;
|
private Bank bank;
|
||||||
|
|
||||||
public Banksystem(String bankname) throws Exception {
|
public Banksystem(String bankname) throws Exception {
|
||||||
if (BankSerializer.sindDatenGespeichert())
|
if (BankSerializer.sindDatenGespeichert(bankname))
|
||||||
this.bank = (Bank) BankSerializer.ladeBankDaten();
|
this.bank = (Bank) BankSerializer.ladeBankDaten(bankname);
|
||||||
else
|
else
|
||||||
this.bank = new Bank(bankname);
|
this.bank = new Bank(bankname);
|
||||||
}
|
}
|
||||||
|
|
||||||
public int kontoAnlegen(String name, int auswahl) throws Exception {
|
public int kontoAnlegen(String name, int auswahl) throws Exception {
|
||||||
Konto k;
|
int kontonummer = bank.addKonto(name, auswahl);
|
||||||
|
|
||||||
if (auswahl == 1)
|
BankSerializer.speichereBankDaten(this.bank, bank.getName());
|
||||||
k = new Konto(name);
|
|
||||||
else
|
|
||||||
k = new Girokonto(name);
|
|
||||||
|
|
||||||
bank.addKonto(k);
|
return kontonummer;
|
||||||
|
|
||||||
BankSerializer.speichereBankDaten(this.bank);
|
|
||||||
BankSerializer.speichereKontozähler(k.getKontozähler());
|
|
||||||
|
|
||||||
return k.getKontonummer();
|
|
||||||
}
|
}
|
||||||
|
|
||||||
public String[] getKontenliste() {
|
public String[] getKontenliste() {
|
||||||
|
@ -47,13 +40,19 @@ public class Banksystem {
|
||||||
return liste;
|
return liste;
|
||||||
}
|
}
|
||||||
|
|
||||||
public long zahleEin(Integer kontonummer, long einzahlung) {
|
public long zahleEin(Integer kontonummer, long einzahlung) throws Exception {
|
||||||
|
BankSerializer.speichereBankDaten(this.bank, bank.getName());
|
||||||
return bank.zahleEin(kontonummer, einzahlung);
|
return bank.zahleEin(kontonummer, einzahlung);
|
||||||
|
|
||||||
}
|
}
|
||||||
public long zahleAus(Integer kontonummer, long einzahlung) {
|
public long zahleAus(Integer kontonummer, long einzahlung) throws Exception {
|
||||||
|
BankSerializer.speichereBankDaten(this.bank, bank.getName());
|
||||||
return bank.zahleAus(kontonummer, einzahlung);
|
return bank.zahleAus(kontonummer, einzahlung);
|
||||||
}
|
}
|
||||||
|
public long zahleAus2(Integer kontonummer, long einzahlung) throws Exception {
|
||||||
|
BankSerializer.speichereBankDaten(this.bank, bank.getName());
|
||||||
|
return bank.zahleAus2(kontonummer, einzahlung);
|
||||||
|
}
|
||||||
|
|
||||||
public long getKontostand(Integer kontonummer) {
|
public long getKontostand(Integer kontonummer) {
|
||||||
return bank.getKontostand(kontonummer);
|
return bank.getKontostand(kontonummer);
|
||||||
|
@ -68,27 +67,33 @@ public class Banksystem {
|
||||||
return bank.getName();
|
return bank.getName();
|
||||||
}
|
}
|
||||||
|
|
||||||
/*public boolean überweisungBeauftragen(int startkonto, int zielkonto, long betrag, String verwendungszweck) {
|
public boolean überweisungBeauftragen(int startkonto, int zielkonto, long betrag, String verwendungszweck) {
|
||||||
Konto start = bank.existiertKonto(startkonto);
|
Konto start = bank.existiertKonto2(startkonto);
|
||||||
Konto ziel = bank.existiertKonto(zielkonto);
|
Konto ziel = bank.existiertKonto2(zielkonto);
|
||||||
|
|
||||||
if (start instanceof Girokonto && ziel instanceof Girokonto) {
|
if (start instanceof Girokonto && ziel instanceof Girokonto) {
|
||||||
return ((Girokonto)start).überweise((Girokonto)ziel, betrag, verwendungszweck);
|
return ((Girokonto)start).überweise((Girokonto)ziel, betrag, verwendungszweck);
|
||||||
}
|
}
|
||||||
|
|
||||||
return false;
|
return false;
|
||||||
}*/
|
}
|
||||||
|
|
||||||
|
|
||||||
public List<Kontoauszug> getAuszuge(Integer kontonummer) {
|
public List<Kontoauszug> getAuszuge(Integer kontonummer) {
|
||||||
return bank.getAuszuge(kontonummer);
|
return bank.getAuszuge(kontonummer);
|
||||||
}
|
}
|
||||||
|
public boolean instanceOfGirokonto(int kontonummer) {
|
||||||
|
Konto start = bank.existiertKonto2(kontonummer);
|
||||||
public void einzahlen(int i) {
|
if(start instanceof Girokonto ) {
|
||||||
// TODO Auto-generated method stub
|
return true;
|
||||||
|
|
||||||
|
}
|
||||||
|
return false;
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
}
|
}
|
|
@ -0,0 +1,54 @@
|
||||||
|
package de.hs_mannheim.informatik.bank.facade;
|
||||||
|
|
||||||
|
import static org.junit.Assert.assertTrue;
|
||||||
|
import static org.junit.jupiter.api.Assertions.*;
|
||||||
|
|
||||||
|
import org.junit.jupiter.api.Test;
|
||||||
|
|
||||||
|
import de.hs_mannheim.informatik.bank.domain.Konto;
|
||||||
|
|
||||||
|
class SystemTest {
|
||||||
|
|
||||||
|
@Test
|
||||||
|
void test() throws Exception {
|
||||||
|
Banksystem bs = new Banksystem("Testsystem");
|
||||||
|
|
||||||
|
assertNotNull(bs);
|
||||||
|
assertEquals(0, bs.getKontenliste().length);
|
||||||
|
assertEquals("Testsystem", bs.getBankname());
|
||||||
|
|
||||||
|
assertEquals(0,bs.getKontenliste().length );
|
||||||
|
|
||||||
|
}
|
||||||
|
@Test
|
||||||
|
void testKontoAnlegen() throws Exception {
|
||||||
|
Banksystem bs = new Banksystem("Testbank");
|
||||||
|
String name = "Peter";
|
||||||
|
int auswahl = 1;
|
||||||
|
bs.kontoAnlegen(name, auswahl);
|
||||||
|
assertNotEquals(bs.getKontenliste(), 0);
|
||||||
|
|
||||||
|
}
|
||||||
|
@Test
|
||||||
|
void testZahelEin() throws Exception {
|
||||||
|
Banksystem bs = new Banksystem("Testbank");
|
||||||
|
//int kontonummer = 1000;
|
||||||
|
long einzahlung = 500;
|
||||||
|
Konto k = new Konto ("Hans",1);
|
||||||
|
bs.zahleEin(1000, einzahlung);
|
||||||
|
assertEquals(bs.getKontostand(1000), 500);
|
||||||
|
|
||||||
|
}
|
||||||
|
@Test
|
||||||
|
void zahleAusTest () throws Exception {
|
||||||
|
Banksystem bs = new Banksystem("Testbank");
|
||||||
|
Konto k = new Konto("Hans", 1);
|
||||||
|
|
||||||
|
int kontonummer = 1001;
|
||||||
|
long einzahlung = 500;
|
||||||
|
bs.zahleEin(1000, einzahlung);
|
||||||
|
bs.zahleAus(1001, 400);
|
||||||
|
assertEquals(bs.getKontostand(1000), 100);
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
|
@ -28,6 +28,7 @@ public class UI {
|
||||||
System.out.println("4 -> Von Konto abheben");
|
System.out.println("4 -> Von Konto abheben");
|
||||||
System.out.println("5 -> Kontostand anzeigen");
|
System.out.println("5 -> Kontostand anzeigen");
|
||||||
System.out.println("6 -> Kontoauszug anzeigen");
|
System.out.println("6 -> Kontoauszug anzeigen");
|
||||||
|
System.out.println("7 -> Überweisung beauftragen");
|
||||||
|
|
||||||
System.out.println("9 -> Beenden");
|
System.out.println("9 -> Beenden");
|
||||||
System.out.println();
|
System.out.println();
|
||||||
|
@ -60,7 +61,8 @@ public class UI {
|
||||||
case 6:
|
case 6:
|
||||||
kontoauszugAnzeigen();
|
kontoauszugAnzeigen();
|
||||||
break;
|
break;
|
||||||
// case 7 : überweisungBeauftragen();break;
|
case 7 : überweisungBeauftragen();break;
|
||||||
|
|
||||||
case 9:
|
case 9:
|
||||||
break mainloop;
|
break mainloop;
|
||||||
default:
|
default:
|
||||||
|
@ -96,7 +98,7 @@ public class UI {
|
||||||
System.out.println();
|
System.out.println();
|
||||||
}
|
}
|
||||||
|
|
||||||
private void kontoEinzahlen() {
|
private void kontoEinzahlen() throws Exception {
|
||||||
// Konto ermitteln
|
// Konto ermitteln
|
||||||
System.out.print("Bitte die Kontonummer angeben: ");
|
System.out.print("Bitte die Kontonummer angeben: ");
|
||||||
Integer kontonummer = Integer.parseInt(sc.nextLine()); // warum kein null check / empty check
|
Integer kontonummer = Integer.parseInt(sc.nextLine()); // warum kein null check / empty check
|
||||||
|
@ -111,18 +113,19 @@ public class UI {
|
||||||
|
|
||||||
// Betrag ermitteln
|
// Betrag ermitteln
|
||||||
System.out.print("Bitte den einzuzahlenden Betrag angeben: ");
|
System.out.print("Bitte den einzuzahlenden Betrag angeben: ");
|
||||||
double betrag = Double.parseDouble(sc.nextLine());
|
long betrag = Long.parseLong(sc.nextLine());
|
||||||
if (betrag <= 0) {
|
if (betrag <= 0) {
|
||||||
System.out.println("Du kannst mit diesem Betrag nicht einzahlen, bitte versuche nochmal");
|
System.out.println("Du kannst mit diesem Betrag nicht einzahlen, bitte versuche nochmal");
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
// Einzahlen
|
// Einzahlen
|
||||||
long kontostand = bs.zahleEin(kontonummer, (long) betrag * 100);
|
bs.zahleEin(kontonummer, betrag);
|
||||||
System.out.print("Konto mit der Nummer " + kontonummer + " hat einen Kontostand von " + kontostand / 100.0);
|
|
||||||
|
System.out.print("Konto mit der Nummer " + kontonummer + " hat einen Kontostand von " + betrag );
|
||||||
System.out.println();
|
System.out.println();
|
||||||
}
|
}
|
||||||
|
|
||||||
private void kontoAbheben() {
|
private void kontoAbheben() throws Exception {
|
||||||
// Konto ermitteln
|
// Konto ermitteln
|
||||||
System.out.println("Bitte die Kontonummer angeben: ");
|
System.out.println("Bitte die Kontonummer angeben: ");
|
||||||
Integer kontonummer = Integer.parseInt(sc.nextLine());
|
Integer kontonummer = Integer.parseInt(sc.nextLine());
|
||||||
|
@ -133,15 +136,21 @@ public class UI {
|
||||||
}
|
}
|
||||||
// Betrag ermitteln
|
// Betrag ermitteln
|
||||||
System.out.println("Bitte den abzuhebenden Betrag angeben: ");
|
System.out.println("Bitte den abzuhebenden Betrag angeben: ");
|
||||||
double betrag = Double.parseDouble(sc.nextLine());
|
long betrag = Long.parseLong(sc.nextLine());
|
||||||
if (betrag <= 0) {
|
if (betrag <= 0) {
|
||||||
System.out.println("Du kannst mit diesem Betrag nicht auszahlen, bitte versuche nochmal");
|
System.out.println("Du kannst mit diesem Betrag nicht auszahlen, bitte versuche nochmal");
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
// Abheben
|
// Abheben
|
||||||
long kontostand = bs.zahleAus(kontonummer, (long) betrag * 100);
|
if(bs.instanceOfGirokonto(kontonummer)) {
|
||||||
System.out.println("Konto mit der Nummer " + kontonummer + " hat einen Kontostand von " + kontostand / 100.0);
|
bs.zahleAus2(kontonummer, betrag);
|
||||||
|
System.out.println("Sie haben ihr konto Überzogen "+(bs.getKontostand(1000)-betrag)+" Euro");
|
||||||
|
return;
|
||||||
|
|
||||||
|
}
|
||||||
|
bs.zahleAus(kontonummer, betrag);
|
||||||
|
System.out.println("Konto mit der Nummer " + kontonummer + " hat einen Kontostand von " + bs.getKontostand(kontonummer) );
|
||||||
}
|
}
|
||||||
|
|
||||||
private void kontoauszugAnzeigen() {
|
private void kontoauszugAnzeigen() {
|
||||||
|
@ -168,26 +177,23 @@ public class UI {
|
||||||
System.out.println(
|
System.out.println(
|
||||||
"Konto mit der Nummer " + kontonummer + " hat einen Kontostand von " + bs.getKontostand(kontonummer));
|
"Konto mit der Nummer " + kontonummer + " hat einen Kontostand von " + bs.getKontostand(kontonummer));
|
||||||
}
|
}
|
||||||
/*
|
|
||||||
* private void überweisungBeauftragen() { System.out.
|
private void überweisungBeauftragen() {
|
||||||
* print("Bitte die Kontonummer des Ausgangskontos der Überweisung eingeben: ");
|
System.out.print("Bitte die Kontonummer des Ausgangskontos der Überweisung eingeben: ");
|
||||||
* int startkonto = Integer.parseInt(sc.nextLine());
|
int startkonto = Integer.parseInt(sc.nextLine());
|
||||||
*
|
|
||||||
* System.out.
|
System.out.print("Bitte die Kontonummmer für das Zielkonto der Überweisung eingeben: ");
|
||||||
* print("Bitte die Kontonummmer für das Zielkonto der Überweisung eingeben: ");
|
int zielkonto = Integer.parseInt(sc.nextLine());
|
||||||
* int zielkonto = Integer.parseInt(sc.nextLine());
|
|
||||||
*
|
System.out.print("Bitte den gewünschten Überweisungsbetrag eingeben: ");
|
||||||
* System.out.print("Bitte den gewünschten Überweisungsbetrag eingeben: ");
|
double betrag = Double.parseDouble(sc.nextLine());
|
||||||
* double betrag = Double.parseDouble(sc.nextLine());
|
|
||||||
*
|
System.out.print("Bitte den Verwendungszweck eingeben: ");
|
||||||
* System.out.print("Bitte den Verwendungszweck eingeben: "); String
|
String verwendungszweck = sc.nextLine();
|
||||||
* verwendungszweck = sc.nextLine();
|
|
||||||
*
|
boolean erfolgreich = bs.überweisungBeauftragen(startkonto, zielkonto, (long)(betrag * 100), verwendungszweck);
|
||||||
* boolean erfolgreich = bs.überweisungBeauftragen(startkonto, zielkonto,
|
|
||||||
* (long)(betrag * 100), verwendungszweck);
|
System.out.println("Überweisung" + ( (!erfolgreich) ? " nicht" : "") + " erfolgreich ausgeführt.");
|
||||||
*
|
}
|
||||||
* System.out.println("Überweisung" + ( (!erfolgreich) ? " nicht" : "") +
|
|
||||||
* " erfolgreich ausgeführt."); }
|
|
||||||
*/
|
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -15,11 +15,11 @@ public class BankSerializer {
|
||||||
private static final String BANK_DATEI = "bank.ser";
|
private static final String BANK_DATEI = "bank.ser";
|
||||||
private static final String ZÄHLER_DATEI = "zähler.ser";
|
private static final String ZÄHLER_DATEI = "zähler.ser";
|
||||||
|
|
||||||
public static boolean sindDatenGespeichert() {
|
public static boolean sindDatenGespeichert(String bankname) {
|
||||||
return new File(BANK_DATEI).exists();
|
return new File(BANK_DATEI).exists();
|
||||||
}
|
}
|
||||||
|
|
||||||
public static void speichereBankDaten(Object bank) throws Exception {
|
public static void speichereBankDaten(Object bank, String name) throws Exception {
|
||||||
ObjectOutputStream oos = new ObjectOutputStream(new FileOutputStream(BANK_DATEI));
|
ObjectOutputStream oos = new ObjectOutputStream(new FileOutputStream(BANK_DATEI));
|
||||||
oos.writeObject(bank);
|
oos.writeObject(bank);
|
||||||
oos.close();
|
oos.close();
|
||||||
|
@ -31,7 +31,7 @@ public class BankSerializer {
|
||||||
oos.close();
|
oos.close();
|
||||||
}
|
}
|
||||||
|
|
||||||
public static Object ladeBankDaten() throws Exception {
|
public static Object ladeBankDaten(String name) throws Exception {
|
||||||
ObjectInputStream ois = new ObjectInputStream(new FileInputStream(BANK_DATEI));
|
ObjectInputStream ois = new ObjectInputStream(new FileInputStream(BANK_DATEI));
|
||||||
Object bank = ois.readObject();
|
Object bank = ois.readObject();
|
||||||
ois.close();
|
ois.close();
|
||||||
|
|
Loading…
Reference in New Issue