Versions Compared

Key

  • This line was added.
  • This line was removed.
  • Formatting was changed.

...

Excerpt

Denne oppgaven handler om å lage en felles abstrakt superklasse Account AbstractAccount for CreditAccount, DebitAccount- og SavingsAccount SavingsAccount2-klassene.

Denne oppgaven er en annen variant SavingsAccount-oppgaven, med fokus på bruk av abstrakte klasser og arv.

Del 1 - Abstrakt klasse

...

AbstractAccount

En bank består av mange ulike type kontoer: sparekontoer, brukskontoer, depositumskontoer, støttekontoer etc. Felles for alle kontoer er den abstrakt Account-klassen, som er en utvidelse grensesnittet fra SavingsAccount-oppgavenAccount-klassen har tre metoder. Siden disse har mye felles, f.eks. har alle en balanse, så er det praktisk å samle så mye som mulig av den felles logikken i en superklasse, som alle kan arve fra. Denne superklassen er imidlertid ikke noen egen type konto, og derfor gjør vi den abstrakt, slik at den ikke kan instansieres. De konkrete konto-klassene som arver fra den, må selvsagt være instansierbare.

Metodene i AbstractAccount-klassen, er omtrent de samme som dem vi definerte i Account-grensesnittet i SavingsAccount-oppgaven, og er som følger:

  • void deposit(double) - øker kontobalansen med innskutt beløp. Merk at det innskutte beløpet må være positivt. Ved ulovlig innskudd skal en IllegalArgumentException utløses.
  • void withdraw(double) -  Metoden kaller internalWithdraw(uttaksbeløp), som implementeres i hver subklasse. Hvis uttaksbeløpet er negativt skal metoden utløse en IllegalArgumentException. 
  • abstract void internalWithdrawabstract void withdraw(double) - minsker  minsker kontobalansen med beløpet som blir tatt ut. Merk at reglene for for uttak er ulik for klassene som implementerer AccountAbstractAccount, og må derfor implementeres i hver klasse. Hvis det ikke er mulig å ta ut det angitte beløpet skal metoden utløse en IllegalStateException.
  • double getbalancegetBalance() - returnerer kontobalansen.

Alle metodene utenom den absktrakte må implementeres. I tillegg må Account AbstractAccount ha en tilstand balance for saldo på kontoen. Saldoen skal settes til 0 i konstruktøren.

Vær oppmerksom på at du i Del 2 skal lage subklasser av Account AbstractAccount og at du ved å bruke rett innkapsling (hintprotected-modifikatoren) kan skal la subklassene nyttiggjøre seg superklassen i størst mulig grad.JExercise-testkode for


Del 2 - DebitAccount extends AbstractAccount

En debetkonto er den enkleste formen for konto, hvor det eneste kravet er at saldoen til enhver tid må være større eller lik 0. DebitAccount skal utvide (arve fra med extends) AbstractAccount og sikre at saldoen aldri blir lavere enn 0.

Testkode for oppgavene finner du her: inheritance/

...

DebitAccountTest.java. Originalkoden (jextest) for testen finner du her: inheritance/

...


Del

...

I tillegg til generelle sparekontoer finnes det en spesiell type sparekonto som heter BSU. Du skal nå lage en BSU-klasse som arver fra SavingsAccount-superklassen. Her er målet at du skal gjenbruke mest mulig av superklassen og samtidig støtte BSU-spesifikk oppførsel. En BSU-konto er, i tillegg til å være en sparekonto, spesiell i den forstand at det kun er lovlig å sette inn inntil et forhåndsbestemt beløp per år (kr 25 000 for 2014 fastsatt av den nye regjeringen) og at det kun er lovlig å ta ut av det beløpet som er satt inn siste år. M.a.o. vil en ved årsskifte få mulighet til å sette inn nye innskudd innenfor innskuddsgrensen, men en har ikke lenger mulighet til å ta ut hele balansen (innskudd fra tidligere år låses). Dessuten gir en BSU-konto 20% skattefradrag for innskudd beløp.

Du må selv avgjøre hvilke felt som må legges til før å støtte den beskrevne oppførsel. I tillegg stilles følgende krav til klassen:

  • BSU(double, double) - konstruktør som tar inn rentefoten på kontoen og et desimaltall som angir hvor mye det er tillatt å sette inn på kontoen per år. 

  • double getTaxDeduction() - returnerer skattefradrag for inneværende år. Dette vil være 20% av innskutt(e) beløp siste år.

3 - CreditAccount extends AbstractAccount

En CreditAccount har i tillegg til balance en tilstand for creditLine, altså tilgjengelig kreditt på kontoen. Denne kredittlinjen tillater at kontoen kan overtrekkes (at saldoen er negativ) innenfor kredittlinjen. Klassen må ha tilgangsmetoder (getters and setters) for creditLine. Merk at kredittlinjen alltid må være større eller lik 0, hvis ikke skal det utløses en IllegalArgumentException. Hvis en ny kredittlinje settes og balansen er negativ, må den nye kredittlinjen dekke den eksisterende balansen. Ellers skal det utløses en IllegalStateException og ingen endring i kredittlinjen.

Konstruktøren CreditAccount(double) skal sette kredittlinjen.

Testkode for JExercise-testkode for oppgavene finner du her: inheritance/BSUTestCreditAccountTest.java. Originalkoden (jextest) for testen finner du her: inheritance/BSUTestCreditAccount.jextest.


Del

3 - ForeldreSpar extends SavingsAccount

En annen spesiell type sparekonto, her kalt ForeldreSpar, har et begrenset antall lovlige uttak per år (ofte i bytte mot en høyere rente). Du skal nå lage en slik ForeldreSpar-klasse som arver fra SavingsAccount-superklassen. Her er igjen målet at du skal gjenbruke mest mulig av superklassen samtidig som støtte ForeldreSpar-spesifikk oppførselen. Denne klassen skal sikre at kun det lovlige antallet uttak gjøres i løpet av et år.

Du må selv avgjøre hvilke felt som må legges til før å støtte den beskrevne oppførsel. I tillegg stilles følgende krav til klassen:

  • ForeldreSpar(double, int) - konstruktør som tar inn rentefoten på kontoen og et heltall som angir antall lovlige uttak per år.

  • int getRemainingWithdrawals() - returnerer antall gjenstående uttak fra sparekontoen.

4 - SavingsAccount2 extends AbstractAccount

En SavingsAccount2 (merk at navnet er endret, for ikke å kræsje med SavingsAccount-klassen fra den tidligere oppgaven!) kan kun ha positiv saldo. I tillegg har kontoen uttaksbegrensinger. En SavingsAccount2 har antall uttak (withdrawals). Dersom man ønsker å ta ut penger etter alle uttak er brukt opp, skal saldoen belastes med et gebyr (fee). Både withdrawals (antall)og fee (beløp) settes i konstruktøren SavingsAccount2(int, double).

 

Testkode for

JExercise-testkode for

oppgavene finner du her: inheritance/

ForeldreSparTest Originalkoden

 Originalkoden (jextest) for testen finner du her: inheritance/

ForeldreSpar.jextest.

SavingsAccount2.jextest.

 

Exercise-panelet

Bruk av Exercise-panelet er obligatorisk for denne øvingen. Du må ha panelet åpent med AbstractAccount.ex-filen (tests > inheritance > AbstractAccount.ex) i før du begynner med oppgaven. For mer informasjon/hjelp, se nederst på forrige side, altså hovedsiden for Øving 9.

 

Include Page
Bunntekst for JExercise- oppgaver
Bunntekst for JExercise- oppgaver