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

Compare with Current View Page History

« Previous Version 11 Next »

I RPN-kalkulator-oppgaven under temaet Tilstand og oppførsel, så ble det definert en oppførsel, men innkapsling i seg selv var ikke et tema. I denne oppgaven skal du bruke synlighetsmodifikatorer for å kapsle inn ordentlig og reflektere over hva slags validering som er nyttig/riktig.

Del 1 - Bruk av synlighetsmodifikatorer

Bruk synlighetsmodifikatorer på metoder og felt for å gjøre innkapslingen "vanntett".

Del 2 - Validering

I oppgaven som denne bygger på, var det spesifisert at peek()- og pop()-metodene skulle returnere Double.NaN hvis stacken var tom. Alternativet er å utløse et unntak.

Spørsmål:

  • Hvilken type unntak vil det være naturlig å bruke.
  • Hvilke fordeler og ulemper ser du for dette alternativet?

Det var også spesifisert at en skulle "håndtere manglende operander på en måte som gir mening for operasjonen". Hvis '+'-operasjonen ble utført på kun én operand, så kunne en f.eks. velge å la den manglende operanden være 0.

Spørsmål:

  • Hva vil tilsvarende verdi for manglende operand for '*'-operasjonen (multiplikasjon) være? Hva med for '/' (divisjon)?
  • Hvordan kan du endre (evt. har du endret) API-et for stack-operasjonene for å gjøre implementasjonen av disse enklere?
  • Også her er et alternativ å utløse unntak. Hva tror du om det?

Prøv koden din

Vi laget en JavaFX-app som du kan bruke for å prøve ut RPNCalc-klassen din (og kanskje lære deg litt app-programmering i tillegg). Her er filene som trengs:

  • RPNCalcFX.java: Selve app-klassen som kjøres som Java-applikasjon .
    RPNCalcFX.fxml: Denne filen må ligge i samme mappe/pakke som RPNCalcFX og beskriver hvordan app-en ser ut.


JExercise-testen finner du herencapsulation/RPNCalcTest.java. Her er den tilsvarende jextest-koden: encapsulation/RPNCalc.jextest


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