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

Compare with Current View Page History

« Previous Version 5 Current »

Oppgaven handler om MobileUsage-klassen, som innkapsler data om bruk av mobilen, og MobileSubscription-klassen, som innkapsler data om abonnement og håndterer utregning av månedsavgift basert på bruk.

Et MobileUsage-objekt inneholder data om bruk av mobilen til telefoni, tekstmeldinger og dataoverføring. MobileUsage-klassen har metoder for å registrere bruk av disse tjenestene og lese av akkumulert forbruk. 

Lesemetoder:

  • MobileUsage() - konstruktøren skal sett alt forbruk til 0.
  • int getCallCount() - returnerer antall samtaler som er akkumulert.
  • int getCallSeconds() - returnerer antall ringesekunder som er akkumulert.
  • int getMessageCount() - returnerer antall tekstmeldinger som er akkumulert.
  • int getBytesReceived() - returnerer antall bytes som er mottatt.
  • int getBytesSent() - returnerer antall bytes som er sendt.

Registreringsmetoder:

  • void registerCall(int seconds) - registrerer ny samtale på det antall sekunder som er angitt.
  • void registerMessage() - registrerer ny melding
  • void registerBytes(int sent, int received) - registrerer mere overførte data, første argument er antall bytes sendt og andre argument er antall bytes mottatt.

For alle registreringsmetodene skal det utløses et IllegalArgumentException, dersom et argument er negativt. I så fall skal objektet ikke endres.

Et MobileSubscription-objekt inneholder data om et abonnement, slik at en kan regne ut månedsavgiften basert på forbruk som er registrert i et MobileUsage-objekt. MobileSubscription-klassen inneholder metoder for å lese og sette følgende hele øreverdier:

  • callCost - kostnad pr. samtale
  • callMinuteCost - kostnad pr. minutt, beregnes pr. sekund
  • messageCost - kostnad pr. melding
  • receiveMBytesCost - kostnad pr. megabyte (1MB = 1024 * 1024 bytes) mottatt
  • sentMBytesCost - kostnad pr. megabyte (1MB = 1024 * 1024 bytes) sendt

For hver av disse er det en get- og en set-metode, med navn etter Java-konvensjonen. Hint: Definer først passende felt og bruk så Eclipse sin innebyggede funksjon for å generere gettere og settere i Source-menyen. Som for registreringsmetodene i MobileUsage, så skal et IllegalArgumentException-unntak utløses for negative argumenter.

I tillegg har MobileSubscription-klassen følgende metode for å regne ut avgift basert på akkumulert forbruk:

  • int computeTotalCost(MobileUsage) - beregner total kostnad for forbruket som er registrert (akkumulert) i MobileUsage-objektet som gis som argument.

Del 1 – Java-kode for MobileUsage

Implementer MobileUsage-klassen iht. kravene over.

Del 2 - Java-kode

Implementer MobileSubscription-klassen iht. kravene over.

 


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