Ohjelmistotekniikan menetelmät, luokkamallin laatiminen

Slides:



Advertisements
Samankaltaiset esitykset
Tuloksellinen Java-ohjelmointi Luku 3 Luokkien käyttäminen
Advertisements

18. Abstraktit tietotyypit
– Ohjelmistojen mallintaminen luokkamallin lisäpiirteitä.
Koostumussuhde Jukka Juslin © Jukka Juslin.
Ohjelmiston tekninen suunnittelu
Osion kaksi kertaus Jukka Juslin © Jukka Juslin.
6. Metodit.
© Jukka Harju, Viittausmuuttujat. © Jukka Harju, Viittaukset •Viittausmuuttuja sisältää tiedon siitä missä muistipaikassa olio.
Luokkakaaviot Luokkakaaviot Tekninen suunnittelu.
Ict1td002: Ohjelmointitaito Kertaus Osio 2 - luokat - ilmentymät - viittaus- ja arvomuuttuja - ilmentymien taulukointi HAAGA-HELIA IltaTiko.
Taulukoiden määrittely, käsittely ja kopiointi Vaihtoehdot taulukoille
OHJELMAN OSITTAMINEN LUOKKA ATTRIBUUTIT METODIT. LUOKKA JAVA ohjelma koostuu luokista LUOKKA sisältää metodeja molemmat sisältävät attribuutteja eli muuttujia.
@ Leena Lahtinen OHJELMAN OSITTAMINEN LUOKKA ATTRIBUUTIT METODIT.
9. Periytyminen Javassa.
© Jukka Harju, Jukka Juslin
1 Kertaus koetta varten oleellisista asioista Jukka Juslin.
20. Javan omat luokat.
– Ohjelmistojen mallintaminen luokkamallin laatiminen
4. Attribuutit 4.1. Sisällys Yleistä attribuuteista. Näkyvyys luokan sisällä ja ulkopuolelta. Attribuuttien arvojen käsittely aksessoreilla. 4.2.
5. Kapselointi Yleistä Kapseloinnilla (encapsulation) tarkoitetaan luokan tietojen ja toimintojen pakkaamista yhdeksi suojatuksi kokonaisuudeksi.
10. Abstrakti luokka Johdanto Abstrakti luokka (abstract class) poikkeaa konkreettisesta luokasta (ei-abstrakti luokka) siten, että siitä ei.
@ Leena Lahtinen OHJELMAN OSITTAMINEN LUOKKA ATTRIBUUTIT METODIT.
Oliot ja luokat Oliot ja luokat Oliot (object) ja luokat (class) ovat keskeisiä olio- ohjelmoinnin käsitteitä. Olio-ohjelmointi on ohjelmointiparadigma,
1 © Jukka Juslin Luokat, attribuutit ja metodit Yleistietoa: seuraavalla koulutusviikolla tarkempi käsittely.
8. Periytyminen Sisällys Mitä on periytyminen? Yksittäis- ja moniperiytyminen. Oliot ja perityt luokat. Periytymisen käyttö.
15. Ohjelmoinnin tekniikkaa
Luokkakohtaiset eli stattiset metodit ja attribuutit ● Ilmaistaan luokkakaaviossa alleviivattuina public class Jonotuskone { private static int yhteinenJuoksevaNumero.
Kertausta: Ohjelmistotuotantoprosessin vaiheet ● Vaatimusanalyysi- ja määrittely – Mitä halutaan? ● Suunnittelu – Miten tehdään? ● Toteutus – Ohjelmointi.
UML-luokkakaavio ● Luokkakaavio (class diagram) kuvaa järjestelmän luokkarakennetta ● Mitä luokkia on olemassa ● Minkälaisia luokat ovat ● Luokkien suhteet.
Olio-ohjelmoinista lyhyesti. 2.2 Sisällys Yleistä. Oliot ja luokat. Attribuutit. Olioiden esittely ja alustus. Rakentajat. Olion operaation kutsuminen.
1 Työtapaturmista ilmoittaminen 2010 Riikka-Liisa Haapanen
17. Kooste.
Koulutuksen ja opetuksen järjestämisen prosessit
6. Metodit.
3. Olio-ohjelmoinista lyhyesti
VARDA-tietovirrat: Varhaiskasvatuksen tietojen siirtyminen tiedon tuottajilta tiedon hyödyntäjille.
Tuloksellinen Java-ohjelmointi
13. Pakkaukset.
Poikkeustenkäsittelylohkot try-catch
17. Javan omat luokat.
8. Näppäimistöltä lukeminen
3. Luokat, oliot ja metodit Java-kielessä (Lausekielinen ohjelmointi I ja II –kursseilla opitun kertausta.)
15. Lohkot.
Luokan määrittely class-määreellä
– Ohjelmistojen mallintaminen, kesä 2010
7. Näytölle tulostaminen
8. Näppäimistöltä lukeminen
Tiedon hallinnan viitearkkitehtuurin osa-alueet
10. Javan ohjausrakenteet
11. Javan valintarakenteet
15. Lohkot.
6. Metodit.
3. Komentoriviparametrit
8. Periytyminen.
4. Attribuutit.
Kaksi erää Tässä ppt:ssä ohjeet pelin johtajalle Opus-työryhmä 2014
15. Ohjelmoinnin tekniikkaa
<Hankkeen nimi>
7. Hyvä ohjelmointitapa..
Aineisto CANopen projektit Simulointikirjasto Prosessi RDF-malli
– Ohjelmistojen mallintaminen luokkamallin lisäpiirteitä
Mallintamisen metamalli ja notaatiot
– Ohjelmistojen mallintaminen, kertausta
Ohjelmistotekniikan menetelmät, sekvenssikaaviot
Kehittämispäällikkö Eija Lappalainen
TIETO JA TIETOKONEOHJELMA
8. Periytyminen.
4. Luokan testaus ja käyttö olion kautta
2. Olio-ohjelmoinnin perusteita
Avoimen tuotteenhallintamalli
Esityksen transkriptio:

582101 - Ohjelmistotekniikan menetelmät, luokkamallin laatiminen

Perussanasto Luettelo organisaation toiminnan kannalta keskeisistä käsitteistä ja niiden määritelmistä Voidaan esittää Koko organisaatiolle liiketoimintatason sanasto Kullekin kohdealueelle tarkemmin ja liiketoimintatason sanastoa laajentaen Auttaa luokkamallin laatimisessa Olioiden, olioiden välisten suhteiden ja olioluokkien löytäminen

Liiketoimintatason luokkamalli Liiketoiminnalliset oliot (business entity) Vain organisaation päätoiminnallisuus ja peruskäsitteet Ei sisällä suunnittelu- eikä toteutustason käsitteitä (esim. käyttöliittymä- tai tietokantayhteysluokkia) Olioiden väliset yhteydet (association) Osallistumisrajoitteet (multiplicity) Koosteisuus (aggregation, composition) Yleistyssuhteet (generalizations) eli periytymishierarkia Ns. POJO-malli (Plain Ordinary Java Objects)

Luokkakaaviot UML:ssä Luokkakaavioilla kuvataan Ohjelmiston tai muun järjestelmän rakenne Olioiden tietosisältö Olioiden ja olioluokkien väliset suhteet Olioiden tarjoamat palvelut

Yhteysviivatyypeistä Erilaisia viivatyyppejä käytetään merkitsemään erilaisia asioita Assosiaatio, riippuvuus, yleistys Yhteystyypin valinta kertoo painotuksesta Kaavioiden tehtävä nä on parantaa ihmisten välistä kommunikaatiota

Luokkasymbolin osat

Luokan ilmentymän kuvaaminen Ilmentymäviitteessä esitetään alleviivattuna joko Ilmentymän nimi/tunniste Luokan nimi Molemmat Alemmassa osassa annetaan ilmentymän attribuuttien arvot Ilmentymiä käytetään yleensä vain esimerkkeinä

Kirahvi (Giraffa camelopardalis) Korkein maanisäkäs. Uroksen korkeus on 4,8–5,5 metriä ja paino jopa 900 kiloa. Kaulanikamia on seitsemän kuten muillakin nisäkkäillä ja niiden pituus on noin 40 cm. Kirahvin turkissa on vaalealla pohjalla eri kokoisia ja muotoisia läiskiä, joiden väri vaihtelee oranssista lähes mustaan. Jokaisen yksilön kuviointi on erilainen. Kirahvi voi elää luonnossa noin 25-vuotiaaksi, tavallisesti elämänkaaren pituus on noin 15–20 vuotta. [Wikipedia]

Luokan attribuutit Kuvaavat olioiden tietosisällön muodon Attribuutista voidaan esittää Nimi (välttämätön) Tietotyyppi (String, Date, int, Kirahvi). Arvojen lukumäärä (multiplicity) Oletusarvona 1, epämääräisen monta = * Annetaan hakasuluissa, [5..*] Näkyvyys (visibility) Oletusarvo Muita määreitä

Attribuutin tyyppi ja arvo Attribuutin arvolla on tyyppi Tyyppi erotetaan attribuutin nimestä kaksoispisteellä (vrt. ilmentymän esittäminen) pvm: Date tai merkki: char Arvo voi olla perustietotyypin arvo, vaikkapa int UML ei rajoita perustietotyyppejä Olio, jolloin tietotyyppinä on olion luokka Olioarvoiset attribuutit esitetään tässä yhteydessä vain, jos olion luokka on perustietotyyppimäinen. String, Date, Color, Point… Muutoin kyseessä on yhteys (association)

Attribuuttilajit ja lisämääreet Attribuutit ovat yleensä ilmentymäattribuutteja (instance attribute) Jokaisella luokan ilmentymällä on oma arvonsa UML:ssä myös luokka-attribuutteja (class attribute) Attribuutilla luokkakohtainen arvo Ilmaistaan alleviivaamalla attribuutin nimi Esim. Eläinten lukumäärän laskeminen Attribuutille voi antaa kaarisulkeissa {…} lisämääreitä UML:ssä valmiina, esim. Frozen Mallintaja voi ottaa käyttöön omia

Näkyvyysmääreet Tekniikka attribuutin tai operaation käytön rajoittamiseen Merkitään erikoismerkillä tai ikonilla nimen eteen Vaihtoehdot: Private (-) sallii käytön vain luokan omissa operaatioissa Protected (#) sallii käytön myös luokan aliluokissa määriteltävissä operaatioissa Package (~) sallii käytön myös muissa saman paketin luokissa määriteltävissä operaatioissa Public (+) sallii käytön kaikkialla Käytetään usein vain ohjelmointiläheisessä kuvauksessa

Esimerkki: erilaisia attribuutteja Luokka-attribuutti seurVapaaNro Näkyvyyssäännöt Private (-) Protected (#) Package (~) Public (+) Tietotyypit Int, String, decimal, Date Lisämääreet {frozen}

Esimerkki: erilaisia attribuutteja Luokkakohtainen seurVapaaNro kertoo seuraavan vapaan tilinumeron Protected-määreet ovat käytettävissä tämän luokan ja aliluokkien operaatioissa Tilinumero:a ei voi muuttaa olion luonnin jälkeen

Esimerkki: erilaisia attribuutteja Tapahtumat on moniarvoinen attribuutti, tyyppi jätetty määrittelemättä Attribuutteihin tapahtumat ja saldo voi viitata vain luokan omissa operaatioissa Attribuuttiin valuuttakoodi voi viitata kaikissa niissä luokissa, jotka sijaitsevassa samassa pakkauksessa kuin tämä luokka

Attribuutit: UML ja Java UML-luokka vastaa Javan luokkaa Javan staattiset kentät (static field) vastaavat luokka-attribuutteja Muut Java-luokassa määritellyt kentät vastaavat ilmentymäattribuutteja UML:n näkyvyysmääreet vastaavat varsin hyvin Javan modifier-määreitä UML:n lisämääreet ({frozen}) saatetaan joutua toteuttamaan itse Javasta löytyy määreitä, jotka jäävät UML:ssä mallintajan kirjoitettavaksi (synchronized, strictfp)

Yhteydet (association) Yhteydet merkitään luokkakaavioon luokkien välisinä viivoina tai nuolina Yhteys merkitsee kyseisten luokkien ilmentymien välistä suhdetta Olioiden väliset yhteydet toteutetaan ohjelmakoodissa olioarvoisena attribuuttina .. Tai jotain muuta epäsuoraa, mutta pysyväisluonteista viittausta käyttäen

Moniarvoisuusmääreet (multiplicity) Kertoo, moniko yhteysluokan ilmentymä yhteyteen liittyy Esim. 1, *, 0..1 tai 1..* Alaraja 0 kertoo yhteyden olevan valinnainen Yläraja * kertoo yhteyksiä voivan olevan määrittelemätötömästi Lyhennysmerkinnät 1=1..1 ja * = 0..*

Esimerkki moniarvoisuusmääreestä Määritellään Java-ohjelmassa Pankkitili-luokan omistus-attribuutti seuraavasti Asiakas[] omitus = new Asiakas[3]; Tarkoittaen, että pankkitilillä voi olla korkeintaan kolme omistajaa Vaaditaan lisäksi, että pankkitilillä on oltava vähintään yksi omistaja Tämä ilmaistaan UML:llä näin:

Yhteyden navigoituvuus Yhteyskuvauksiin liitetty nuoli ilmaisee, että kyseessä on suunnattu yhteys Pankkitili tuntee omistajansa, mutta omistaja ei muista tilejään Tarvittaessa yhteydet voidaan suunnata molemminsuuntaisiksi

Esimerkki oliokaaviona

Yhteyksien yhdistäminen ja nimeäminen Ilmentymätasolla navigoitavat yhteydet ovat aina kaksisuuntaisia. Tällöin yhteydet voidaan yhdistää: Yhteydelle voi antaa nimen molempiin suuntiin Yhteyttä ei ole pakollista nimetä Nuoli yhteyden nimessä merkitsee lukusuunnan

Roolinimet Roolinimiä voidaan käyttää yhteysnimien lisäksi Esim. tili, omistaja Roolinimi voidaan [joskus] johtaa ohjelmakoodista, yhteyden toteuttavan kentän nimestä Roolinimi merkitään yhteyden kohteen päähän

Yhteyksien kuvaaminen eri abstraktiotasoilla Luokkia korkealla abstraktion tasolla kuvattaessa voimme jättää attribuutit ja/tai operaatiot merkitsemättä Vastaavasti, navigointimahdollisuus voidaan pudottaa pois Yhteysviivan kummassakaan päässä ei merkitä nuolenkärkeä

Yhteyksien kuvaamisen abstrahointi Navigointimahdollisuus jätetty esittämättä: Tämä tarkoittaa, että navigoiminen on mahdollista kumpaankin suuntaan Nuolenpää omistajasta suuntaan pankkitili Tämä kuvaa sveitsiläistä pankkitiliä – omistaja tietää tilinsä, mutta tili ei omistajaansa.

Yhteys samaan luokkaan Molemmat yhteyden osapuolina olevat oliot voivat kuulua samaan luokkaan Esimerkki: työntekijällä on vain yksi välitön esimies Esimiehellä taas n alaista Ylimmällä päälliköllä ei ole esimiestä

Esimies-alainen –suhde oliokaaviona

Ilmentymien järjestys Yhteyteen voidaan liittää järjestysmääre ilmaisemaan, että olioon yhteydessä olevien olioiden joukko on jollain perusteella järjestetty Esimerkki: kirjan kirjoittajat on järjestetty

Operaatioiden määritteleminen UML:ssä Operaatioille annettavat tiedot Näkyvyys (kuten attribuuteille) Nimi (ainut pakollinen osa) Parametrit Paluuarvon tyyppi Muut määreet Syntaksi (hakasuluilla merkitään optionaalinen osuus) [näkyvyys] nimi [(parametrit)] [: paluuarvon tyyppi] [{muut määreet}] l parametrimäärittelyn muoto on l[suunta] nimi: tyyppi [= oletusarvo]

Henkilötunnus-luokan attribuutit ja operaatiot Henkilötunnusta mallintavalla luokalla on neljä julkista operaatiota Yksi operaatioista on konstruktori Operaatio getBirthDate palauttaa Date-tyyppisen olion Konstruktorille annetaan parametrina henkilötunnus merkkijonona

Kysymyksiä ?