You are viewing an old version of this page. View the current version.

Compare with Current View Page History

« Previous Version 6 Next »

Oppgaven handler om en AdvancedAccount-klasse, som håndterer data i en konto. Denne klassen er en utvidelse av Account-klassen, men stiller større krav til innkapsling og validering.Tilstanden i AdvancedAccount-objekter er som følger:

  • balance - et desimaltall som angir beløpet som er på kontoen
  • interestRate - et desimaltall som angir rentefot som prosentpoeng

Begge verdiene settes når objektet opprettes og ingen av verdiene kan være negative. Hvis et argument i konstruktøren ikke er gyldig skal tilstanden settes til 0.

AdvancedAccount-klassen har i tillegg til metodene deposit og addInterest en ny metode withdraw, med følgende oppførsel:

  • withdraw(double) – reduserer konto-beløpet med den angitte argument-verdien. Metoden skal returnere den nye balansen. Hvis argument-verdien er større enn konto-beløpet, skal metoden kaste en IllegalArgumentException som forklarer hva som er galt.
  • Klassen må også ha passende tilgangsmetoder etter hvordan man velger å innkapsle tilstanden. Eksempelvis, bør man kunne endre konto-beløpet på andre måter enn gjennom deposit(double) og withdraw(double)?

Del 1 – Innkapsling og validering: teori

Ta utgangspunkt i koden fra Account-klassen og besvar følgende spørsmål:

  1. Hva er riktig innkapsling for de ulike tilstandene og metodene i denne klassen?
  2. Hvilken validering må legges til for å sikre gyldige tilstander?
  3. Er denne klassen data-orientert eller tjeneste-orientert? Begrunn svaret!

Del 2 - Java-kode

Implementer endringene fra Account-klassen i den nye AdvancedAccount-klassen med oppførsel som er beskrevet over.

JExercise-testkode for denne oppgaven finner du her: stateandbehavior/AdvancedAccountTest.java


JExercise lar deg sjekke din egen kode vha. forhåndslagde JUnit-tester og JExercise-panelet

Bruk av JExercise:

  1. Sørg for at jexercise-standalone.jar er lagt til i ditt prosjekts Build Path. Dette må gjøres hver gang du oppretter et nytt prosjekt, og det er derfor lurt å gjenbruke samme prosjekt til alle oppgaver.
  2. JExercise-tillegget må være installert. Installer tillegget fra følgende oppdateringsadresse: http://folk.ntnu.no/hal/dev/updatesite.
  3. Åpne JExercise-panelet via Window -> Show View -> Other, og navigere deg fram til JExercise i vinduet som kommer opp, velge det og klikke OK.
  4. Klikke og dra oppgavens testklasse, <oppgavenavn>Test.java fra pakkeoversikten og slippe den i JExercise panelet. 
  5. Testene kan så kjøres ved å dobbeltklikke på testen som ønskes kjørt.

Ved trøbbel, se først om du finner løsningen i Løsninger på trøbbel med JExercise.

Unknown macro: {html}

Twitre gjerne om oppgaven når du er ferdig: <a href="https://twitter.com/share" class="twitter-share-button" data-hashtags="jexercise">Tweet</a>
<script>!function(d,s,id){var js,fjs=d.getElementsByTagName(s)[0],p=/^http:/.test(d.location)?'http':'https';if(!d.getElementById(id)){js=d.createElement(s);js.id=id;js.src=p+'://platform.twitter.com/widgets.js';fjs.parentNode.insertBefore(js,fjs);}}(document, 'script', 'twitter-wjs');</script>

 

 

  • No labels