Ohjelmistotuotanto, suunnittelu Syksy Suunnittelu. Suunnittelun tulos. Suunnitteluprosessin työvaiheet. Suunnitteluprosessi.

Samankaltaiset tiedostot
6. Suunnittelu. Suunnittelun tulos

Suunnittelun tulos. 6. Suunnittelu. Suunnitteluprosessin työvaiheet. Suunnitteluprosessi. 6.1 Arkkitehtuurisuunnittelu.

6. Suunnittelu. Suunnitteluprosessi

Ohjelmistojen suunnittelu

Suunnitteluvaihe prosessissa

5. Järjestelmämallit. Mallinnus

Mallinnus. 5. Järjestelmämallit. Abstraktiot. Mallinnuksen etuja. Arkkitehtuurimalli. Yhteysmallit. Ohjelmistotuotanto, järjestelmämallit Kevät 2005

1. Johdanto. Ohjelmistotuotannon ongelmia

2. Ohjelmistotuotantoprosessi

Ohjelmiston toteutussuunnitelma

Suunnittelumalleja, MVC. Juha Järvensivu 2008

Rajapinnasta ei voida muodostaa olioita. Voidaan käyttää tunnuksen tyyppinä. Rajapinta on kuitenkin abstraktia luokkaa selvästi abstraktimpi tyyppi.

Prosessimalli. 2. Ohjelmistotuotantoprosessi. Prosessimallin vaihejako. Prosessimallien perustehtävät. Ohjelmiston suunnittelu. Vaatimusmäärittely

Ohjelmistojen mallinnus Ohjelmistoarkkitehtuuri Harri Laine 1

Sisällys. JAVA-OHJELMOINTI Osa 7: Abstrakti luokka ja rajapinta. Abstraktin luokan idea. Abstrakti luokka ja metodi. Esimerkki

Rutiinin muodostaminen. 2. Rutiinin muodostaminen. specification) Määrittely (specification( Määrittelyn osapuolet. Hyvän ohjelman tunnusmerkit

Opintojakso TT00AA11 Ohjelmoinnin jatko (Java): 3 op Rajapinnat ja sisäluokat

Tenttikysymykset. + UML-kaavioiden mallintamistehtävät

812347A Olio-ohjelmointi, 2015 syksy 2. vsk. VIII Suunnittelumallit Observer ja State

Sisällys. 11. Rajapinnat. Johdanto. Johdanto

Harjoitustyön testaus. Juha Taina

Ohjelmistotuotanto, prosessit Syksy Ohjelmistotuotantoprosessi. Prosessimalli. Prosessimallien perustehtävät. Prosessimallin vaihejako

Ohjelmistojen mallintaminen, mallintaminen ja UML

Tietojärjestelmän osat

Ohjelmistotuotanto vs. muut insinööritieteet. (Usein näennäinen) luotettavuus ja edullisuus

Graafisen käyttöliittymän ohjelmointi Syksy 2013

1. Johdanto. Ohjelmistotuotannon piirteitä

Sisällys. Ratkaisumallien historia. Ratkaisumalli. Ratkaisumalli [2] Esimerkki: Composite [2] Esimerkki: Composite. Jaakko Vuolasto 25.1.

Copyright by Haikala. Ohjelmistotuotannon osa-alueet

Uudelleenkäytön jako kahteen

Ohjelmistoarkkitehtuurit Syksy 2009 TTY Ohjelmistotekniikka 1

9. Muunneltavuuden hallinta

Ohjelmistojen mallintaminen, arkkitehtuuria ja rajapintoja

Interaktiivisten järjestelmien arkkitehtuuriratkaisu, jolla käyttöliittymä erotetaan sovelluslogiikasta.

Kehyksillä toteuttettujen tuotelinjojen rakenteellinen optimointi

Tenttikysymykset. + UML- kaavioiden mallintamistehtävät

1. Johdanto. Ohjelmistotuotannon piirteitä

1. Olio-ohjelmointi 1.1

Hyvin määritelty on puoliksi tehty kuinka vältetään turha tekeminen jo alussa

1. Johdanto. Ohjelmistotuotannon piirteitä. Ohjelmisto ja järjestelmä. Osajärjestelmät ja käyttäjät. Järjestelmän ja ohjelmiston laadinta

Interaktiivisten järjestelmien arkkitehtuuriratkaisu, jolla käyttöliittymä erotetaan sovelluslogiikasta.

Digi-tv vastaanottimella toteutetut interaktiiviset sovellukset

812341A Olio-ohjelmointi Peruskäsitteet jatkoa

Oliosuunnitteluesimerkki: Yrityksen palkanlaskentajärjestelmä

13/20: Kierrätys kannattaa koodaamisessakin

Ohjelmistoarkkitehtuurit. Syksy 2010

1. Johdanto. Ohjelmistotuotannon piirteitä. Ohjelmisto ja järjestelmä. Osajärjestelmät ja käyttäjät. Järjestelmän ja ohjelmiston laadinta

Suunnittelumallien käyttö ohjelmistosuunnittelussa

SEPA REFAKTOROINTI Antti Ahvenlampi, 57408L Erik Hakala, 57509T

Verifioinnin ja validoinnin ero. 7. Verifiointi ja validointi. Verifiointi- ja validointitekniikat. Verifiointi- ja validointitekniikat II

Solidity älysopimus ohjelmointi. Sopimus suuntautunut ohjelmointi

Hirviö. Design Patterns

812347A Olio-ohjelmointi, 2015 syksy 2. vsk. IX Suunnittelumallit Proxy, Factory Method, Prototype ja Singleton

T Henkilökohtainen harjoitus: FASTAXON

Ohjelmistoprojektien hallinta Vaihejakomallit

58160 Ohjelmoinnin harjoitustyö

Arkkitehtuurikuvaus. Ratkaisu ohjelmistotuotelinjan monikielisyyden hallintaan Innofactor Oy. Ryhmä 14

Rajapinta (interface)

Ohjelmistotekniikan menetelmät, UML

Ohjelmistojen mallintamisen ja tietokantojen perusteiden yhteys

Palveluperustaiset arkkitehtuurityylit

Käyttäjien tunnistaminen ja käyttöoikeuksien hallinta hajautetussa ympäristössä

Sovellusarkkitehtuurit

Concurrency - Rinnakkaisuus. Group: 9 Joni Laine Juho Vähätalo

Sisällys. 18. Abstraktit tietotyypit. Johdanto. Johdanto

Yksikkötestaus. import org.junit.test; public class LaskinTest public void testlaskimenluonti() { Laskin laskin = new Laskin(); } }

Järjestelmäarkkitehtuuri (TK081702)

Uutisjärjestelmä. Vaatimusmäärittely. Web-palvelujen kehittäminen. Versio 1.3

TIE Samuel Lahtinen. Lyhyt UML-opas. UML -pikaesittely

3. Komponentit ja rajapinnat

T Ohjelmistojen määrittely- ja suunnittelumenetelmät Harjoitustyöraportti TNT - Tarkistetaan Ne Tentit Analyysimalli

Ohjelmistojen mallintaminen

Ohjelmistoarkkitehtuurit Syksy 2009 TTY Ohjelmistotekniikka 1

Testaussuunnitelma PULSU. Syksy 2008 Ohjelmistotuotantoprojekti. HELSINGIN YLIOPISTO Tietojenkäsittelytieteen laitos

Analyysi, staattinen mallintaminen, kohdealueen malli ja luokkakaavio

Ohjelmistoarkkitehtuurit. Syksy 2008

Ohjelmistotekniikan menetelmät, suunnittelumalleja

Ohjelmistoarkkitehtuurit. Kevät

Ohjelmistotekniikan menetelmät, toteutuksesta ja testauksesta

Ohjelmistotuotanto. Luento

ELM GROUP 04. Teemu Laakso Henrik Talarmo

Tarjolla tänää: Ohjelmiston toteutuksesta. Kuinka tulla hyväksi ohjelmoijaksi? CRC-kortit. Testilähtöinen kehittäminen JOT2007. Uudelleenrakentaminen

TIE Tietorakenteet ja algoritmit 1. TIE Tietorakenteet ja algoritmit

ohjelman arkkitehtuurista.

18. Abstraktit tietotyypit 18.1

UML- mallinnus: Tilakaavio

Testausdokumentti. Kivireki. Helsinki Ohjelmistotuotantoprojekti HELSINGIN YLIOPISTO Tietojenkäsittelytieteen laitos

12. Kehysarkkitehtuurit

Ohjelmistoarkkitehtuurit

Ohjelmistotuotanto, verifiointi ja validointi Syksy Verifioinnin ja validoinnin ero. 7. Verifiointi ja validointi

opiskelun suunnittelujärjestelmä, kurki ja ilmo käyttävät kaikki samaa tietokantaa, ja uusi järjestelmä tulee osaksi tätä.

1. Johdanto. Ohjelmistotuotannon piirteitä

4. Vaatimusanalyysi. Vaatimusanalyysin tavoitteet

Ohjelmistotuotanto, vaatimusanalyysi Syksy Vaatimusanalyysi. Implisiittiset vaatimukset. Eksplisiittiset vaatimukset

Yhteydelle voi antaa nimen kumpaankin suuntaan Sille ei tarvise antaa lainkaan nimeä Yhteysnimen asemasta tai lisäksi voidaan käyttää roolinimiä

Malliperustainen ohjelmistokehitys - MDE Pasi Lehtimäki

Tapahtuipa Testaajalle...

Ohjelmointi 2 / 2010 Välikoe / 26.3

Sopimuspohjainen olio-ohjelmointi

A TIETORAKENTEET JA ALGORITMIT

Transkriptio:

6. Suunnittelu Suunnittelun tulos Vaatimusanalyysin jälkeen seuraava työvaihe on suunnittelu. Siinä vaatimusanalyysin korkean abstraktiotason malleja käyttämällä luodaan alempien abstraktiotasojen malleja. Tavoitteena on kuvata tehtävä ohjelmisto sellaisella tarkkuudella, että sen toteutus on suoraviivaista. Syksy 2004 Ohjelmistotuotanto / Verkamo, Taina 1 Suunnittelun tuloksena saadaan kuvaukset toteutettavasta ohjelmistosta, sen tarvitsemista ja tuottamista tiedoista, ulkomaailman rajapinnoista ja mahdollisesti käytetyistä algoritmeista. Tulokset kirjataan suunnitteludokumenttiin. Dokumentti on sekä suunnittelun että ylläpidon lähdeteos. Syksy 2004 Ohjelmistotuotanto / Verkamo, Taina 2 Suunnitteluprosessi Suunnitteluprosessin työvaiheet Requirements analysis Requirements specification Design activities Architectural Abstract Interface Component design specification design design System Software Interface Component architecture specification specification specification Design products Kuvalla osittainen (C) I. Sommerville 2000 Data structure design Data structure specification Algorithm design Algorithm specification Oliopohjainen suunnittelu voidaan jakaa kuuteen osavaiheeseen: 1. Arkkitehtuurisuunnittelu (Architectural design) 2. Abstrakti määrittely (Abstract specification) 3. Rajapintasuunnittelu (Interface design) 4. Komponenttisuunnittelu (Component design) 5. Tietorakennesuunnittelu (Data structure design) 6. Algoritmisuunnittelu (Algorithm design) Syksy 2004 Ohjelmistotuotanto / Verkamo, Taina 3 Syksy 2004 Ohjelmistotuotanto / Verkamo, Taina 4 6.1 Arkkitehtuurisuunnittelu Osajärjestelmät Käytännössä jokainen ohjelma rakentuu osajärjestelmistä, jotka ovat itsenäisiä yhteistyötä tekeviä järjestelmiä. Osajärjestelmiä käytetään erottamaan metsä (koko järjestelmä) puilta (yksittäiset komponentit). Ilman osajärjestelmiä saatava arkkitehtuuri luokkineen olisi niin laaja, että sitä ei voisi hahmottaa kunnolla. Syksy 2004 Ohjelmistotuotanto / Verkamo, Taina 5 Osajärjestelmä on kokonainen järjestelmä, joka toimii itsenäisesti riippumatta muiden järjestelmien tarjamista palveluista. Osajärjestelmä rakentuu komponenteista ja sisältää rajapinnat muille osajärjestelmille. Osajärjestelmä saattaa rakentua useasta aliosajärjestelmästä. Syksy 2004 Ohjelmistotuotanto / Verkamo, Taina 6 Verkamo, Taina 1

Moduulit/komponentit Arkkitehtuurimallit Moduuli on komponentti, joka tarjoaa palveluita muille moduuleille. Moduuli ei ole itsenäinen kuten osajärjestelmä. Se on vahvasti sidottu muihin moduuleihin. Sommerville ei anna selkeitä määritelmiä osajärjestelmälle, moduulille ja komponentille. Jatkossa pidämme moduulia ja komponenttia synonyymeina. Syksy 2004 Ohjelmistotuotanto / Verkamo, Taina 7 Osajärjestelmät tunnistetaan ja jaotellaan suunnittelun alkuvaiheessa. Apuna käytetään arkkitehtuurimalleja, kuten esimerkiksi seuraavia: Tietovarastomalli (Repository model) Osajärjestelmät erotellaan tehtävien mukaan. Kaikki osajärjestelmät käyttävät tietokantaosajärjestelmää, johon talletetaan yhteiskäytössä oleva tieto. Kukin osajärjestelmä pitää yllä omaa paikallista tietovarastoa. Syksy 2004 Ohjelmistotuotanto / Verkamo, Taina 8 Arkkitehtuurimallit - II Lisää osajärjestelmistä Asiakas-palvelin -arkkitehtuuri (Clientserver architecture) Osa osajärjestelmistä on palvelimia, jotka tarjoavat palveluja. Loput ovat asiakkaita, jotka käyttävät palvelimien tarjoamia palveluita. Abstraktin koneen malli (Abstract machine model) Osajärjestelmät ovat sisäkkäisiä. Jokainen tarjoaa abstraktiotason palveluihin. Mitä alemmalla abstraktiotasolla ollaan, sitä lähempänä ollaan laitteistotasoa. Syksy 2004 Ohjelmistotuotanto / Verkamo, Taina 9 Osajärjestelmien jaottelun täytyy olla sellainen, että sen tehtävällä ja tarjoamilla palveluilla on selvät rajat. Sitä mukaa kun osajärjestelmät tunnistetaan ja suunnitellaan, niiden täytyy toteuttaa seuraavat ehdot: Jokaisella osajärjestelmällä on hyvin määritelty rajapinta, jonka kautta se tarjoaa palveluja muille osajärjestelmille. Syksy 2004 Ohjelmistotuotanto / Verkamo, Taina 10 Osajärjestelmälle asetetut ehdot Osajärjestelmiä on vain muutama. Osajärjestelmä voidaan osittaa sisäisesti aliosajärjestelmiksi, jos tällainen jaottelu on luonnollinen ja jos muussa tapauksessa osajärjestelmästä tulisi laaja ja vaikeaselkoinen. Osajärjestelmä rakentuu rajapinnan toteuttavista ulkoisista komponenteista ja palvelut toteuttavista sisäisistä komponenteista. Syksy 2004 Ohjelmistotuotanto / Verkamo, Taina 11 Arkkitehtuurisuunnitelma Arkkitehtuurisuunnittelun tuloksena saadaan arkkitehtuurisuunnitelma. Se kuvaa löydetyt osajärjestelmät, niiden tehtävät, jaottelun moduuleiksi ja osajärjestelmien välisen yhteistyön. Arkkitehtuurisuunnitelma sisältää yleensä joukon kaaviokuvia ja yksityiskohdista kertovat kuvaustekstit Syksy 2004 Ohjelmistotuotanto / Verkamo, Taina 12 Verkamo, Taina 2

Esimerkkiarkkitehtuuri 6.2 Abstrakti määrittely Radar Transponder Position Backup processor position processor Aircraft simulation Weather map Accounting Kuvalla (C) I. Sommerville 2000 Data comms. Flight plan database Controller info. Comms. processor Aircraft comms. Activity logging Telephone Backup comms. processor Air Traffic Control architecture Controller consoles Löydetyille osajärjestelmille tehdään kuvaus, joka sisältää seuraavat kohdat: osajärjestelmän tehtävä, osajärjestelmän tarjoamat palvelut, osajärjestelmän säännöt ja rajoitukset, osajärjestelmän mahdollinen rinnakkaisuus muiden osajärjestelmien kanssa ja mahdolliset aliosajärjestelmät abstrakteine määrittelyineen. Syksy 2004 Ohjelmistotuotanto / Verkamo, Taina 13 Syksy 2004 Ohjelmistotuotanto / Verkamo, Taina 14 6.3. Rajapintasuunnittelu Rajapintojen määrittely Rajapintasuunnittelu on ehkä suunnittelun tärkein työvaihe. Siinä jokaisen osajärjestelmän rajapinta muihin osajärjestelmiin suunnitellaan ja dokumentoidaan yksityiskohtaisesti. Osajärjestelmien rajapintojen pitää olla sellaiset, että osajärjestelmän tarjoamia palveluja voidaan käyttää tietämättä niiden toteutuksesta mitään. Syksy 2004 Ohjelmistotuotanto / Verkamo, Taina 15 Osajärjestelmien rajapintojen määrittelyt tulee tehdä yksiselitteisiksi ja ristiriidattomiksi. Luonnollinen kieli ei moniselitteisyytensä vuoksi riitä rajapintojen määrittelyyn. Ohjelmointikielikään ei välttämättä ole paras tapa määritellä rajapintoja, sillä ohjelmointikieli menee helposti turhan matalalle abstraktiotasolle. Syksy 2004 Ohjelmistotuotanto / Verkamo, Taina 16 Rajapintaformalismi Rajapinnan määrittelyyn voidaan käyttää jotain formalismia, kuten Sommervillen luvussa 9.2. Toisaalta formalismia tärkeämpää on valittu abstraktiotaso. Kuvauksesta täytyy selvitä tarvittavat tiedot ilman turhia toteutusriippuvia yksityiskohtia. Rajapinnan kuvaus Esimerkiksi seuraava kuvaustapa sopii rajapinnoille: Rajapinnan nimi: Nimi voi kuvata myös yhtä rajapinnan palvelua tai palvelujoukkoa. Yleinen kuvaus: Yleinen kuvaus on vapaamuotoinen selostus rajapinnan tarjoamista palveluista. Syksy 2004 Ohjelmistotuotanto / Verkamo, Taina 17 Syksy 2004 Ohjelmistotuotanto / Verkamo, Taina 18 Verkamo, Taina 3

Rajapinnan kuvaus - II Rajapinnan kuvaus - III Rajapinnan tarjoamat palvelut. Jokaisesta palvelusta nimi, yleinen kuvaus, sisään otettavat parametrit arvojoukkoineen, ulos annettavat tulokset arvojoukkoineen, poikkeustilanteet, alkuehdot ja loppuehdot. Syksy 2004 Ohjelmistotuotanto / Verkamo, Taina 19 Sisään otettavat parametrit arvojoukkoineen vastaavat metodin parametreja. Ulos annettavat tulokset arvojoukkoineen vastaavat metodin tulosta. Poikkeustilanteet kertovat, mihin erikoistapauksiin palvelussa varaudutaan. Syksy 2004 Ohjelmistotuotanto / Verkamo, Taina 20 Rajapinnan kuvaus - IV Alkuehto on jokin ehto, jonka on oltava voimassa ennen kuin palvelua voidaan käyttää. Loppuehto on jokin ehto, joka on voimassa, kun palvelu on suoritettu. Alku- ja loppuehdot eivät ole pakollisia. Syksy 2004 Ohjelmistotuotanto / Verkamo, Taina 21 Rajapintaesimerkki Nimi: Juuri Kuvaus: Toisen asteen yhtälön ratkaisu. Palvelu Juuri Kuvaus: Toteuttaa rajapinnan Juuri Parametrit sisään: a,b,c : R (reaalilukuja) Parametrit ulos: r 1,r 2 : R (reaalilukuja) Poikkeustilanteet: a = 0 (ei toisen asteen yhtälö) Alku- ja loppuehdot: Ei ole Syksy 2004 Ohjelmistotuotanto / Verkamo, Taina 22 Rajapintaesimerkki javalla public interface Juuri { class result { double r1; double r2; // juuret int roots; // juurten määrä }; public result Juuri(double a, double b, double c) throws aiszeroexception; }; Kuvaukset, alku- ja loppuehdot pitää laittaa kommentteina. Syksy 2004 Ohjelmistotuotanto / Verkamo, Taina 23 6.4. Komponenttisuunnittelu Kun osajärjestelmien rajapinnat on suunniteltu huolellisesti, rajapintojen tarjoamien palveluiden toteutus ei vaikuta rajapintoihin. Rajapinnalle voi olla monta toteutusta ja toteutus voi toteuttaa monta rajapintaa. Komponenttisuunnittelu on osajärjestelmien rajapinnan toteutusta. Syksy 2004 Ohjelmistotuotanto / Verkamo, Taina 24 Verkamo, Taina 4

Komponentit Komponentti ei ole täysin itsenäinen. Se toimii yhteistyössä muiden osajärjestelmän komponenttien kanssa. Jokaisella komponentilla on rajapinta, jonka kautta päästään käsiksi komponentin tarjoamiin palveluihin, ja rajapinta, joka luettelee palvelut, jotka komponentti tarvitsee toimiakseen. Oliot Lopuksi jokainen komponentti rakentuu joukosta yhteistyötä tekeviä olioita, jotka komponenttien tapaan ovat joko sisäisiä tai ulkoisia olioita. Ulkoiset oliot toteuttavat komponentin määrittelemän rajapinnan. Sisäiset oliot tarjoavat palvelut, joita ulkoiset oliot tarvitsevat rajapinnan toteutukseen. Syksy 2004 Ohjelmistotuotanto / Verkamo, Taina 25 Syksy 2004 Ohjelmistotuotanto / Verkamo, Taina 26 Suunnittelun ja toteutuksen suhde 6.5. Tietorakennesuunnittelu Suunnittelutasolla jaottelu järjestelmäosajärjestelmä-komponentti-olio toimii hyvin. Toteutuksessa osajärjestelmistä alaspäin oliot ovat kaikkien rajapintojen toteuttajina. Suoritettavassa ohjelmistossa on vain olioita ja osajärjestelmiä. Syksy 2004 Ohjelmistotuotanto / Verkamo, Taina 27 Kun järjestelmä on saatu jaettua osajärjestelmiin, komponentteihin ja olioluokkiin, voidaan miettiä kunkin elementin käyttämiä tietorakenteita. Tietorakenteet voivat olla ulkoisia, jolloin niitä käytetään osajärjestelmän sisällä useista komponenteista tai olioluokista, tai ne voivat olla sisäisiä, jolloin ne näkyvät vain tietylle olioluokalle. Syksy 2004 Ohjelmistotuotanto / Verkamo, Taina 28 6.6. Algoritmisuunnittelu 6.7. Olioiden tunnistus Algoritmisuunnittelu on suunnitteluprosessin viimeinen vaihe. Siinä valituista ei-triviaaleista palveluista tehdään pseudokieliset kuvaukset. Kaikista palveluista ei kannata tehdä kuvauksia, sillä varsinkin sisäisiä palveluita on paljon ja useimmat niistä ovat kohtullisen suoraviivaisia toteutettavia. Syksy 2004 Ohjelmistotuotanto / Verkamo, Taina 29 Ohjelmiston jako osajärjestelmiin, komponentteihin ja olioihin on hyvä idea, mutta mistä nämä hienot elementit löydetään? Osajärjestelmät löydetään yleensä vaatimusanalyysissa ja viimeistään arkkitehtuurisuunnittelussa. Samat arkkitehtuurit toimivat samantyyppisissä ohjelmistoissa. Syksy 2004 Ohjelmistotuotanto / Verkamo, Taina 30 Verkamo, Taina 5

Olioiden tunnistus - II Seuraavat menetelmät sopivat osajärjestelmien, komponenttien ja olioiden tunnistamiseen: Sanalistat (grammatical analysis). Järjestelmän kuvauksista etsitään substantiiveja ja verbejä. Substantiivit ovat luokka-, komponentti- ja osajärjestelmäehdokkaita. Verbit ovat palveluehdokkaita. Olioiden tunnistus - III Konkreettiset ehdokkaat. Järjestelmästä tunnistetaan konkreettisia kohteita (esim. koneita), toimijoita (esim. asiakkaita), tapahtumia (esim. palvelupyyntöjä), yhteistyötä (esim. tapaamisia), paikkoja (esim. toimistoja), organisaatiota (esim. yrityksiä) jne. Näitä käytetään analyysin pohjana. Analyysia täydennetään tietorakenteilla ja algoritmeilla. Syksy 2004 Ohjelmistotuotanto / Verkamo, Taina 31 Syksy 2004 Ohjelmistotuotanto / Verkamo, Taina 32 Olioiden tunnistus - IV Toiminnan ymmärrys. Ensin kootaan joukko näkemyksiä tehtävästä ohjelmistosta. Jokainen näkemys sisältää joukon palveluita, jotka tunnistetaan ja sijoitellaan osajärjestelmiin. Lisäksi tunnistetaan järjestelmän toimijat ja toiminnan tulokset. Olioiden tunnistus - V Skenaariolähtöinen analyysi. Jokainen löydetty skenaario analysoidaan. Skenaarion perusteella mietitään tarvittavat osajärjestelmät, komponentit ja luokat, joiden avulla skenaario on toteutettavissa. Skenaarioista eristetyt elementit yhdistetään yhteen koko järjestelmän kuvaukseksi. Syksy 2004 Ohjelmistotuotanto / Verkamo, Taina 33 Syksy 2004 Ohjelmistotuotanto / Verkamo, Taina 34 Olioiden tunnistus - VI 6.8. Uudelleenkäyttö Listatut menetelmät antavat raakaelementtejä, jotka on jalostettava lopullisiksi osajärjestelmiksi, komponenteiksi ja luokiksi. Kaikkia menetelmiä käytetään usein samaan aikaan, jolloin yhdessä saadaan kattava kuva järjestelmän komponenteista ja korkean tason olioluokista. Syksy 2004 Ohjelmistotuotanto / Verkamo, Taina 35 Oliopohjaisten menetelmien aikakaudella ohjelmiston osien uudelleenkäyttö on lisääntynyt huomattavasti. Uudelleenkäyttö säästää suunnittelu- ja toteutuskustannuksia, mutta voi lisätä ylläpitokustannuksia. Muuttuvat vaatimukset vaikuttavat sekä rajapintoihin että toteutukseen. Syksy 2004 Ohjelmistotuotanto / Verkamo, Taina 36 Verkamo, Taina 6

Uudelleenkäytön prosessi Komponenttipohjainen suunnittelu Koko suunnitteluprosessi tehdään sellaiseksi, että toteutuksessa voidaan käyttää jo aiemmin suunniteltuja, toteutettuja ja dokumentoituja ohjelman osia; suunnittelussa voidaan eristää osia, jotka voidaan dokumentoida ja tallettaa käytettäväksi muissa projekteissa. Syksy 2004 Ohjelmistotuotanto / Verkamo, Taina 37 Komponenttipohjaisessa suunnittelussa pyritään yhtäältä käyttämään jo olemassaolevia komponentteja ja toisaalta eristämään uusia komponentteja yleiseen käyttöön. Pelkät olioluokat ovat huonoja eristettäviä. Luokat ovat erikoistuneita ja oliot ovat usein vahvasti kytkeytyneitä muihin olioihin. Syksy 2004 Ohjelmistotuotanto / Verkamo, Taina 38 Komponentit uudelleenkäytössä Komponenttien tarjoamat palvelut Komponentti on abstraktimpi käsite kuin olio(luokka). Komponentti kapseloi yhden tai useamman yhteistyössä olevan olioluokan kokonaisuudeksi. Komponentti sopii hyvin uudelleenkäyttöön. Olioa korkeamman abstraktiotason käsitteenä se on toteutusriippumatomampi ja itsenäisempi kuin olio. Syksy 2004 Ohjelmistotuotanto / Verkamo, Taina 39 Komponentit tarjoavat palveluja rajapintansa kautta. Palveluiden toteutus, käytetty ohjelmointikieli ja jopa suoritusalusta eivät näy palvelupyynnön esittäjälle. Komponenttien koko ja kompleksisuus voivat vaihdella yksinkertaisista funktioista täydellisiin järjestelmiin, kuten tietokannan hallintajärjestelmä. Syksy 2004 Ohjelmistotuotanto / Verkamo, Taina 40 Komponentin rajapinnat Komponentin rakenne Komponentilla on kaksi rajapintaa, sisään ja ulos: Komponentti tarjoaa rajapinnan, joka määrittelee komponentin tarjoamat palvelut. Komponentti tarvitsee rajapinnan, joka kuvaa järjestelmältä vaadittavat palvelut. Kuvalla (C) I. Sommerville 2000 Syksy 2004 Ohjelmistotuotanto / Verkamo, Taina 41 Requires interface Component Provides interface Sommervillen mukaan komponentin lähdekoodi ei ole saatavilla - komponentti on määritelty rajapintansa mukaan. Todellisuudessa vain jotkut valmiina ostetut komponentit ovat vailla lähdekoodia. Syksy 2004 Ohjelmistotuotanto / Verkamo, Taina 42 Verkamo, Taina 7

Ohjelmistojen tuoteperheet Esimerkkituoteperheitä Ohjelmistojen tuoteperhe (software product family) on joukko tuotteita, joilla on jokin suunnittelua helpottava yhteys. Tuoteperheen jäsenet voivat toteuttaa ohjelmistot, joilla on samankaltainen käyttöliittymä ja ulkonäkö (look and feel), saman ohjelmiston eri alustoille, saman ohjelmiston eri ulkoisille liittymille tai ohjelmistot, joilla on yhteinen ydin. Syksy 2004 Ohjelmistotuotanto / Verkamo, Taina 43 Esimerkiksi seuraavat ovat ohjelmistojen tuoteperheitä: Microsoft Office (yhteinen ydin) Nokian kännyköiden käyttöohjelmistot (yhteinen ydin ja käyttöliittymä) Halo (videopeli) (sama ohjelmisto eri alustoille) ja ohjelmoitavien logiikoiden tuoteperheet (sama ohjelmisto eri ulkoisille liittymille) Syksy 2004 Ohjelmistotuotanto / Verkamo, Taina 44 Tuoteperheen edut Tuoteperheen tunnistaminen ja käyttö helpottaa vaatimusanalyysiä. Yhteisistä piirteistä seuraa yhteisiä vaatimuksia. suunnittelua. Yhteiset osat voidaan suunnitella kerralla. Vain sovellusriippuvat osat joudutaan suunnittelemaan erikseen. testausta. Testaus voidaan yhtenäistää ja yksinkertaistaa käyttämällä samoja testitapauksia sovellusten välillä. Syksy 2004 Ohjelmistotuotanto / Verkamo, Taina 45 Tuoteperheen haitat Toisaalta tuoteperheet vaikeuttavat vaatimusanalyysia. Aina ei ole selvää, mitkä tuotteet kuuluvat tuoteperheeseen. suunnittelua. Jotta tuoteperheestä on etua, perheen yhteiset osat on tunnistettava, rajapinnoista on tehtävä sellaiset, että tuoteperheen tuotteet voidaan toteuttaa ja ytimen toimintojen on sovittava kaikille tuotteille testausta. Hallintatyötä tulee lisää. Syksy 2004 Ohjelmistotuotanto / Verkamo, Taina 46 Hyvä tuoteperhe Hyvän tuoteperheen edut ovat selvästi vahvemmat kuin haitat. Hyvä tuoteperhe: perheen tuotteilla on niin paljon yhteistä, että yhteisistä osista saatava säästö voittaa haitoista syntyvät kustannukset. Tuoteperheen suunnittelussa on oltava tarkkana, että ei yritetä tehdä tuoteperhettä tuotteista, joilla ei ole tarpeeksi yhteistä. Syksy 2004 Ohjelmistotuotanto / Verkamo, Taina 47 Tuoteperheen suunnittelu Tuoteperhe suunnitellaan vaiheittain: Ensin tunnistetaan ja suunnitellaan tuoteperheen yhteinen osa (ydin). Jatkossa tuotteita lisätään perheeseen yksitellen. Jokaisen tuotteen kohdalla tarkistetaan, että tuote voi käyttää tunnistettua ydintä. Riittää, että lisättävä tuote käyttää osaa ytimestä, jos ytimen käyttämättömät osat eivät häiritse sovelluskohtaisia osia. Syksy 2004 Ohjelmistotuotanto / Verkamo, Taina 48 Verkamo, Taina 8

Suunnittelumallit Valmiiden komponenttien käyttö suunnittelussa onnistuu silloin, kun sopivia komponentteja on saatavilla. Vaikka komponentit olisi suunniteltava ja toteutettava itse, suunnittelussa voidaan käyttää hyväksi hyväksi havaittuja suunnitteluperiaatteita. Suunnittelumallit - II Hyväksi havaittuja suunnitteluperiaatteita kutsutaan suunnittelumalleiksi (design patterns). Suunnittelumallit lähtevät ajatuksesta, että samat perusrakenteet toistuvat oliopohjaisessa suunnittelussa jatkuvasti. Syksy 2004 Ohjelmistotuotanto / Verkamo, Taina 49 Syksy 2004 Ohjelmistotuotanto / Verkamo, Taina 50 Suunnittelumallit - III Malli tarjoaa nimensä mukaisesti hyväksi havaitun menetelmän ratkaista tunnettu suunnitteluongelma. Ratkaisu on yleensä esitetty sellaisella abstraktiotasolla, että sen perusteella voidaan tehdä sopivia toteutuksia erilaisiin sovelluksiin ja ympäristöihin. Suunnittelumallien edut ja haitat Vaikeinta suunnittelumalleissa on tunnistaa oikea malli oikeaan tehtävään. Yleisimmät mallit tulevat kuitenkin hyvin nopeasti tutuiksi ja käyttökelpoisiksi. Mallien hallinta ja käyttö helpottaa huomattavasti hyvien oliopohjaisten ratkaisujen suunnittelua. Syksy 2004 Ohjelmistotuotanto / Verkamo, Taina 51 Syksy 2004 Ohjelmistotuotanto / Verkamo, Taina 52 Suunnittelumallin rakenne Suunnittelumallin rakenne - II Suunnittelumallin kuvaus sisältää seuraavat osat: Mallin nimi Nimi on mallia kuvaava tunniste suunnittelumallille. Kuvaus Kuvaus selittää, mikä on mallin tehtävä ja miten malli toimii. Mallin nimi ja kuvaus yhdessä kertovat suunnittelijalle, onko mallille käyttöä suunnitelmassa. Syksy 2004 Ohjelmistotuotanto / Verkamo, Taina 53 Ongelmakuvaus Ongelmakuvaus selittää ongelmakentän, mihin malli tuo ratkaisun. Ratkaisukuvaus Ratkaisukuvaus selittää ratkaisussa tarvittavat osat, niiden tehtävät ja osien väliset suhteet. Ratkaisukuvaus astetta abstraktimmalla tasolla kuin yksityiskohtainen kieliriippuva toteutus. Seuraukset Seurauksissa kuvataan mallin käytön seuraukset ja mahdolliset sivuvaikutukset. Syksy 2004 Ohjelmistotuotanto / Verkamo, Taina 54 Verkamo, Taina 9

Suunnittelumalliesimerkki Esimerkkinä suunnittelumalleista esitän Observer-suunnittelumallin (tarkkailija? no miten vaan). Observer-mallia käytetään, kun olion tilasta tarvitaan useita erilaisia esityksiä. Malli erottaa esitettävän olion esityksen toteuttavista olioista. Obsever-mallin avulla voidaan esimerkiksi kuvata samaa tietoa taulukkona, piirakkana tai käyränä. Kun tieto muuttuu, muutokset näkyvät automaattisesti kaikissa Observermallilla toteutetuissa tiedon esitysnäkymissä. Syksy 2004 Ohjelmistotuotanto / Verkamo, Taina 55 Syksy 2004 Ohjelmistotuotanto / Verkamo, Taina 56 Suunnittelumalliesimerkki (jatkuu) C D B A Subject A B C D 0 Observer 1 A: 40 B: 25 C: 15 D: 20 Observer 2 Kuvalla (C) I. Sommerville 2000 Syksy 2004 Ohjelmistotuotanto / Verkamo, Taina 57 50 25 Suunnittelumalli Observer Nimi Observer Kuvaus Eristää olion tilan esityksen itse oliosta Ongelmakuvaus Observer ratkaisee tilanteen, missä samasta oliosta tarvitaan automaattisesti muuttuvia erilaisia näkymiä. Syksy 2004 Ohjelmistotuotanto / Verkamo, Taina 58 Suunnittelumalli Observer - II Ratkaisukuvaus Observer Ratkaisukuvaus Seuraavalla kalvolla UML:lla. Seuraukset Tilan esitysten optimointi on epäkäytännöllistä. Subject Attach (Observer) Detach (Observer) Notify () for all o in observers o -> Update () Observer Update () ConcreteSubject ConcreteObserver GetState () subjectstate return subjectstate Update () observerstate observerstate = subject -> GetState () Kuvalla (C) I. Sommerville 2000 Syksy 2004 Ohjelmistotuotanto / Verkamo, Taina 59 Syksy 2004 Ohjelmistotuotanto / Verkamo, Taina 60 Verkamo, Taina 10