1. Modellering av objektorienterte systemer

Like dokumenter
Modellering av objektorienterte systemer

1. Modellering av objektorienterte systemer

Modellering 1. Modellering

God objektorientert design Flere UML diagrammer UML Distilled kap. 7,8, 9 Using UML, kap. 11, 12, 14 Kirsten Ribu

Hva gjøres i design? 19. september 2002, Tore Berg Hansen, TISIP

det offentlige kartgrunnlaget (DOK)

1. Objektorientert systemutvikling

Hva gjøres i analysen? 2. oktober 2001, Tore Berg Hansen, TISIP

UML-Unified Modeling Language. Prosess-oversikt. Use case realisering

I dag UML. Domenemodell visualisering av konsepter. Eksempel. Hvordan finne domeneklasser?

UML-Unified Modeling Language

1. Objektorientert systemutvikling

UML 1. Use case drevet analyse og design Kirsten Ribu

Gruppenavn. Prosjektnavn Beskrivelse av design For Navn på systemet. Versjon <1.0>

Kap3: Klassemodellering

Løsningsforslag til Case. (Analysen)

Flere design mønstre. 19. september 2002, Tore Berg Hansen, TISIP

UKE 11 UML modellering og use case. Gruppetime INF1055

UML- Use case drevet analyse og design. Domenemodeller Sekvensdiagrammer Use case realisering med GRASP patterns Klassediagram - designmodeller

Use Case-modellering. INF1050: Gjennomgang, uke 04

Gruppenavn. Beskrivelse av arkitektur For Navn på systemet. Versjon <1.0>

Hensikten med denne delen av kurset. Objektets egenskaper. Objektorientering hva er det? Best practises ved programvareutvikling. Kravspesifikasjonen

Inception Elaboration Construction Transition Bemanning 1 1,5 2 2 Varighet i uker Antall iterasjoner (lengde i uker i parentes) Tabell 1

Model Driven Architecture (MDA) Interpretasjon og kritikk

21. Objektorientert Analyse (OOA) Kap. 21 Objektorientert Analyse (OOA)

Fra krav til modellering av objekter

Universitetet i Oslo Institutt for informatikk. Eskild Busch. UML hefte

2. HVA ER EN KOMPONENT?

Fra krav til objekter. INF1050: Gjennomgang, uke 05

Programvare arkitekturer

Use case drevet design med UML

UKE 13 Mer UML modellering. Gruppetime INF1055 Julie Hagen Nilsen & Maria Stolinski

Kravspesifikasjon med UML use case modellering. Erik Arisholm

Objektorientering og UML. INF1050: Gjennomgang, uke 06

IN2001: Kravhåndtering, modellering, design

1. Designe ER-modeller med MS Visio

Use case modellen. Use case modellering i analysefasen. Hva er en Aktør? Hva er et Use case? Use case modellering. Eksempel

Gruppenavn. Prosjektnavn Kravdokument For Navn på systemet. Versjon <1.0>

INF1000: Forelesning 7

INF1000: Forelesning 7. Konstruktører Static

Modellering av data. Magnus Karge, Kartverket

DRI2001 h04 - Forelesning Systemutvikling og nettsteder

Tittel Objektorientert systemutvikling 2

SRD GLIS. Cecilie Dortea Gløsmyr, Espen Buø og Henrik Lie

Oppgave 1: Multiple choice (20 %)

AlgDat 12. Forelesning 2. Gunnar Misund

Etter uke 9 skal du. Introduksjon til objektorientert programmering. Innhold. Klasser som abstraksjoner

UNIVERSITETET I OSLO

Use case modellen. Use case modellering i analysefasen. Hva er en Aktør? Hva er et Use case?

Mer om objektorientering og UML

SOSI-forvaltning - logisk modell

Førsteamanuensis John I. Dalseng Høgskolen i Finnmark 9500 Alta

Spesifikasjon av Lag emne

Modellering av krav. INF1050: Systemutvikling 11. februar Universitetslektor Yngve Lindsjørn

A Study of Industrial, Component-Based Development, Ericsson

IN2000:&Kravhåndtering,&modellering,&design

Eksekveringsrekkefølgen (del 1) Oppgave 1. Eksekveringsrekkefølgen (del 2) Kommentar til oppgave 1. } // class Bolighus

EKSAMENSFORSIDE SKRIFTLIG EKSAMEN

GJENNOMGANG UKESOPPGAVER 7 REPETISJON

GJENNOMGANG UKESOPPGAVER 4 USE CASE MODELLERING HELGA NYRUD & KRISTIN BRÆNDEN

Ansvarsdrevet OO: CRC og UML Sekvensdiagrammer

Trafikanten Pluss, delleveranse 2. Gruppe 8 Eivind Hasle Amundsen [eivinha] og Eigil Moe [eigilmo]

1. Mer om iterative utviklingsprosesser

Kravspesifikasjon med. UML diagrammer. systemutvikling. Dokumentasjon av systemets krav, arkitektur, design og implementasjon

Lykke til! Eksamen i fag TDT4140 Systemutvikling NTNU Norges teknisk-naturvitenskapelige universitet

Kravspesifikasjon med. Erik Arisholm

Unified Modeling Language (UML) Kravspesifikasjon med UML use case modellering. UML diagrammer. Notasjon som støtter opp under modellbasert

1. Datamodellering Kommentarer til læreboka

UNIVERSITETET I OSLO

Modellering av krav. INF1050: Systemutvikling 07. februar Førstelektor Yngve Lindsjørn

Innhold uke 10. Objektorientert programmering i Python. Oblig 7 og 8. IN1000 Seminar! IN1000 Høst 2018 uke 10 Siri Moe Jensen

SRD GLIS. Cecilie Dortea Gløsmyr, Espen Buø og Henrik Lie

19. januar 2012 Noen punkter fra i går

Modellering av brukstilfeller og forretningsprosesser. Kurs i standarder, Oslo, 12. juni 2018

Distribuerte objekter og objekt-basert mellomvare

EKSAMEN I FAG SIF MMI OG GRAFIKK Lørdag 16. august 2003 Tid: kl

Innholdsfortegnelse INNHOLDSFORTEGNELSE... 2 REVISJONSOVERSIKT...4 INTRODUKSJON MED FORUTSETNINGER... 5

Innhold. Innledning Del 1 En vei mot målet

INF1010 MVC i tekstbaserte programmer

SOSI standard - versjon Del 1: Regler for navning av geografiske elementer. DEL 1: Regler for navning av geografiske elementer

UNIVERSITETET I OSLO

Kravspesifisering (3): Forhold til OO Analyse og Design

EKSAMENSOPPGAVE. Vil det bli gått oppklaringsrunde i eksamenslokalet? Svar: NEI

INF5120 Oblig gjennomgang

Mer$om$objektorientering$og$UML

Innhold uke 7. Objektorientert programmering i Python: Introduksjon. Lite tilbakeblikk: Programflyt og skop. Lite tilbakeblikk: Funksjoner er uttrykk

Læringsmål uke 7. Objektorientert programmering i Python: Introduksjon. Innhold uke 7. Lite tilbakeblikk: Programflyt og skop

Tom Røise IMT2243 : Systemutvikling 1. IMT2243 Systemutvikling 26. februar Klassediagrammet. Klasse

Metode for ansvarsdrevet OO. Dagens forelesning. Delegering av ansvar i en trelagsarkitektur

Om prosesser 1. Om prosesser

Forslag til løsning. Oppgave 1

Tittel Objektorientert systemutvikling 3

1. Leksjon 01: Introduksjon til faget Prosjektrettet systemarbeid

DRI 2001 Systemutviklingsarbeidet et overblikk Forelesning

Transkript:

Tore Berg Hansen 3.2.2004 Opphavsrett: Forfatter og Stiftelsen TISIP Lærestoffet er utviklet for faget LV339D Objektorientert systemutvikling 1. Resymé: I denne leksjonen skal vi se på hva som genererelt ligger i begrepet modellering. Vi går så over på modellering av objektorienterte systemer og introdusere modelleringsspråket Unified Modelling Language (UML). Innhold 1.1. HVA ER EN MODELL... 2 1.2. HVORFOR MODELLERE... 2 1.3. UML... 3 1.3.1. Litt historie... 4 1.4. BYGGEKLOSSENE I UML... 4 1.4.1. Strukturelle ting... 5 1.4.2. Oppførselsting... 6 1.4.3. Grupperingsting... 6 1.4.4. Merknadsting... 6 1.4.5. Forhold... 7 1.5. ET EKSEMPEL... 8 1.5.1. Use case modell... 8 1.5.2. Domenemodellen... 13 1.5.3. Analysemodellen... 15 1.5.4. Designmodellen... 17 1.6. SLUTTKOMMENTAR TIL DENNE LEKSJONEN.... 19 1.7. REFERANSER... 20

1.1. Hva er en modell Modell har flere betydninger. I en ordbok leser vi følgende: 1. Representasjon av noe. Vanligvis mindre enn originalen. F.eks modelljernbane. 2. Noe som lages for å brukes til kopiering i et annet materiale. F.eks voksmodell av noe som skal støpes. 3. Bestemt type eller design av et produkt. F.eks bilmodell. 4. Forenklet beskrivelse av et system brukt ved forklaring. F.eks en økonomisk modell. 5. Noe som man kan arbeide etter. F.eks en oppskrift. 6. Person eller ting som anses som eksepsjonelle og som det er verdt å etterligne. 7. Person som poserer. F.eks mannekeng eller akt. 8. Utgaver av klær fra motedesignere. Innenfor vårt fag, systemutvikling, er det 4 og 5 som er aktuelle. Vi har behov for å beskrive forskjellige sider og egenskaper ved programvaresystemer og vi følger utviklingsmodeller når vi utvikler systemene. Også 6 er aktuell i forbindelse med begrepet mønstre (engelsk patterns) som er løsninger som har vist seg å fungere godt i systemer som er utviklet tidligere. Jeg gjorde en gang et søk på Internett i et forsøk på finne noe relevant stoff om modeller og modellering. Jeg fant ikke det jeg håpet å finne. Men en av de tingene jeg fant var dette. Her er det flere typer modeller. Hvilke? 1.2. Hvorfor modellere Innefor mange fagområder er det vanlig å lage modeller. Hensiktene kan være flere. Å få prøvet ut ting under kontrollerte betingelser i mindre skala før man setter i gang produksjon. Eksempler er utprøving i vindtunneler av fly og biler. Man sparer penger fordi modellene er billigere å lage enn det endelige produktet. Å ha noe fast å kommunisere rundt for forskjellige interessenter i et prosjekt. I et systemutviklingsprosjekt er det brukere, analytikere, designere, testere, programmerere og eksperter innen forskjellige fagområder. Forskjellige modeller kan brukes til å belyse forskjellige egenskaper ved det tenkte systemet. Det er lettere å føre diskusjoner mellom forskjellige interessenter om egenskapene til et programvareprodukt som er modellert, enn et som bare eksisterer i form av programkode. Når større byområder planlegges lager byplanleggerne modeller som viser hvordan området vil ta seg ut. Slike modeller gir et grunnlag for å fatte beslutninger. Modellene gir bedre forståelse for eventuelle problemer. Å ha et utgangspunkt for en realisering. Snekkere arbeider vanligvis ut fra arbeidstegninger når de setter opp hus. De samme tegningene kan side 2 av 20

også brukes i en diskusjon mellom arkitekten og de som skal bebo huset. Når barn bygger hytter i trær, trengs ingen arbeidstegning. Men skal det settes opp et bolighus er det helt nødvendig for å komme frem til ønsket utforming. Modeller gir med andre ord bedre design. Modellene bidrar til å belyse kravene til det ønskede system. Å håndtere kompleksitet. Gjennom modeller kan man abstrahere bort detaljer og betrakte problemer på et nivå hvor det er mulig å holde oversikten. Vi oppsummerer: Vi lager modeller slik at vi bedre kan forstå de systemene vi vil utvikle. I [1] settes det opp fire grunnprinsipper for modellering: - Vær nøye med hvilke modeller du velger fordi valg av modell har grunnleggende betydning for hvordan man angriper et problem og for hvilken løsning som lages. - Forskjellige modeller gir ulikt detaljeringsnivå. Noen ganger har man behov for å vise et oversiktsbilde, andre ganger er det detaljene man vil konsentrere seg om. En bruker er interessert i å se hvordan systemet vil se ut utenfra, mens en utvikler kan vikle seg inn i detaljer rundt realiseringen av systemet. - De beste modeller er knyttet til virkeligheten. Det gjelder også for programvare. Objektorientert modellering gjør det lettere å oppnå dette. - Det er ikke nok med en enkelt modell. Store systemer vises best gjennom et lite sett med nesten uavhengige modeller. Gjennom utviklingsprosessen lager vi forskjellige modeller. Modeller er sentrale artefakter i de forskjellige disipliner (se leksjon 1). De raffineres i alle faser i livsløpet. Men de forskjellige modeller har ulik betydning i de forskjellige faser. F.eks arbeider man mer med use case modeller i de to første fasene (av UP). 1.3. UML UML [1] er et modelleringsspråk The Unified Modelling Language. Eller litt mer pragmatisk sagt det er det settet med byggeklosser som gir oss muligheten for å modellere alle viktige sider ved et programvaresystem. Det er et modelleringsspråk fordi det gir oss et vokabular i form av symboler og et sett med regler for hvordan disse symbolene kan brukes for å vise konsepter og den fysiske representasjon av systemet. Vi bruker UML til fire ting. Vi bruker det til å visualisere, spesifisere, konstruere og dokumentere programvaresystemer. UML er et utgangspunkt for å realisere systemer fordi modellene direkte kan avbildes i programmeringsspråk som Java og C++. Under utvikling av programvare fremstilles en rekke produkter både dokumenter og eksekverbar kode: - Krav - Arkitektur - Kildekode - Prosjektplaner - Tester - Prototyper side 3 av 20

- Frislipp UML bidrar til å gjøre disse produkter mer forståelige. 1.3.1. Litt historie Objektorientering er relativt ungt. Mange personer har bidratt med metoder og tilhørende modeller. Blant disse mange er de som er blitt kjent som de tre amigos, nemlig Grady Booch, James Rumbaugh og Ivar Jacobson. UML er resultatet av at disse tre har samordnet (unified) sine metoder og notasjoner i et felles språk. Grady Booch var sterk på design og er kjent for å ha utviklet et rikt modelleringsspråk. James Rumbaugh står bak OMT (Object Modeling Technique) som var sterk på analyse. Ivar Jacobson er kanskje mest kjent for sine Use Case og OOSE som legger sterk vekt på å modellere oppførsel (funksjonalitet). 1.4. Byggeklossene i UML Generelt kan man si at et språk består av et sett med symboler som utgjør ordforrådet og regler for hvordan disse symbolene skal settes sammen og tolkes for å gi mening. Slik er det med naturlige språk, og man gjør de samme betraktninger når det gjelder formelle språk. Eksempler på formelle språk er programmeringsspråk. Og altså språk brukt til visuell modellering. Språk analyseres gjerne på tre nivåer: 1. Det leksikalske nivå hvor man ser på ordene som språket består av og hva som er lovlige ord. 2. Det syntaktiske nivå hvor man ser på reglene for hvordan ord kan settes sammen til setninger. 3. Det semantiske nivå hvor man ser på hvilken mening setninger har. Av og til legger man inn ett ekstra nivå mellom det syntaktiske og det semantiske nivå hvor man er interessert i å se på hva som er tillatte setninger i gitte sammenhenger. Dette nivået kalles gjerne det kontekstuelle nivå. I sin brukermanual [1] lanserer de tre amigos tre typer byggeklosser som utgjør ordforrådet i UML. Disse er: - Ting (Things) - Forhold (Relationships) - Diagrammer (Diagrams) Ting består igjen av: - Strukturelle ting - Oppførselsting - Grupperingsting - Merknadsting Av forhold er det fire typer: - Avhengighet side 4 av 20

- Assosiasjon - Generalisering - Realisering Det er ni fundamentale diagrammer: - Klassediagram - Objektdiagram - Use case diagram - Sekvensdiagram - Samarbeidsdiagram - Tilstandsdiagram - Aktivitetsdiagram - Komponentdiagram - Deploymentdiagram Ting og forhold dreier seg om hvilke symboler som brukes i UML. Samtidig uttrykker de sammenhengene (konseptene) som vi vil få frem i modellene. Diagrammene er grafisk visualisering av de forskjellige konsepter. Vi skal i det etterfølgende se litt nærmere på disse begrepene. 1.4.1. Strukturelle ting UML er altså et modelleringsspråk. De strukturelle tingene er substantivene i språket. De utgjør de statiske delene i modellene og kan være både konseptuelle, dvs logiske, og fysiske ting. De strukturelle tingene er klasser, grensesnitt, samarbeidsforhold, use case, aktive klasser, komponenter og noder. Alle disse er representert med grafiske symboler i UML. Objektorientert systemutvikling dreier seg om klasser og objekter. Klasser og instanser av klasser (objekter) og deres samarbeidsmønstre utgjør den statiske strukturen i programvaresystemet. Derfor vil man alltid lage klassediagrammer for systemet. Et grensesnitt beskriver en ekstern tjeneste som en klasse eller en samling klasser skal tilby. Grensesnitt er spesielt relevant i moderne distribuerte systemer. Disse bygges opp av distribuerte komponenter som kan være på et hvilket som helst sted i et nettverk. Komponentene gjør seg tilgjengelig gjennom et definert grensesnitt som publiseres i nettet ved hjelp av en broker som f.eks CORBA. Et samarbeidsforhold er en samling klasser, grensesnitt og andre elementer som arbeider sammen. De tilbyr funksjonalitet som er større enn summen av funksjonaliteten til enkeltelementene. Use case er et sentralt begrep hentet fra Jacobsons [1] utviklingsmetode og tatt med i UML. Kort kan vi si at en use case er et samspill mellom en ekstern bruker og det programvaresystemet som skal utvikles. I denne sammenheng kalles brukeren en aktør. En aktør behøver ikke være et menneske, men kan også være andre systemer som skal samspille med programvaresystemet. En aktør representerer en rolle som spilles i forhold til systemet. Gjennom en use case ser vi programvaresystemet utenfra. Gjennom en use case blir en aktør side 5 av 20

tilbudt noe av nytte fra systemet. Settet med alle use case er den totale funksjonalitet som systemet tilbyr sine brukere. Aktive klasser har instanser som eier en eller flere prosesser eller eksekverbare tråder. Det betyr at de kan kontrollere utførelsen av et program eller deler av et program. De kan også være samtidige. En komponent er en fysisk del av et programvaresystem. En komponent kan være en eksekverbar del av systemet. En komponent representerer typisk den fysiske pakkingen av elementer som ellers er logisk relaterte. En node er en maskinressurs. Et program eller deler av et program eksekverer på noder. Dvs at en node vil huse en eller flere komponenter. 1.4.2. Oppførselsting Oppførsel uttrykker dynamikken i tid og rom i et programvaresystem. Prinsippielt er det to typer oppførsel. Man bruker begrepet interaksjon når flere objekter samarbeider gjennom utveksling av meldinger seg imellom for å oppnå et resultat. For at meldinger skal kunne sendes fra et objekt til et annet må det være en lenke (forbindelse) mellom objektene. Objekter vil i løpet av sin levetid kunne være i forskjellige tilstander. Dette kan modelleres som tilstandsmaskiner. 1.4.3. Grupperingsting I større systemer vil det alltid være behov for å kunne gruppere deler av systemet for å få bedre oversikt. Den primære grupperingstingen er pakke. En pakke samler flere strukturelle og oppførselsting som er tett koblet. En pakke kan igjen bestå av flere pakker. 1.4.4. Merknadsting Dette er forklaringer. Det er gjerne tekstlige forklaringer og anmerkninger som kan være nødvendige for å øke forståelsen av en modell eller spesielle deler av en modell. Nedenfor er en oversikt over de symboler som brukes. Strukturelle ting i UML Tilhørende symbol i UML klasse grensesnitt (interface) side 6 av 20

Strukturelle ting i UML Tilhørende symbol i UML samarbeid use case aktiv klasse komponent node oppførsel melding gruppering tilstand merknad 1.4.5. Forhold Jeg har tillatt meg å oversette det engelske relationship med forhold. Dette har jeg gjort for å skille det fra begrepet relasjon (eng relation) som er et matematisk begrep. En annen ting er at et forhold kan være en relasjon i matematisk forstand. I UML kan man modellere fire typer av forhold: - Avhengighet side 7 av 20

- Assosiasjon - Generalisering - Realisering Et avhengighetsforhold har vi når en klasse bruker en annen klasse. Vanligvis kommer det til uttrykk ved at en klasse er parameter i en operasjon til en annen klasse. En assosiasjon er et forhold hvor det eksisterer en forbindelse mellom objekter. Dette kan sammenlignes med E-R modeller for relasjonsdatabaser. Forskjellen ligger i at en entitet i en E-R modell bare innkapsler data, mens objekter innkapsler både data og oppførsel. Generalisering er det samme som arv. Et generaliseringsforhold kommer til uttrykk gjennom et spesialiserings/generaliserings-hierarki. De spesialiserte elementer er subtyper av generelle typer som blir en supertype. Realisering har vi når en klasse oppfyller en kontrakt, f.eks spesifisert i et grensesnitt (interface). Ting og forhold utgjør det leksikalske nivå i UML fordi det dreier seg om symbolene som brukes for å bygge opp modellene. På det syntaktiske, kontekstuelle og semantiske nivå befinner modellene seg. Her dreier det seg om hva som er vel formulerte modeller. Dvs regler for å kombinere modeller og hvordan modellene skal tolkes. 1.5. Et eksempel Vi skal her se på et eksempel for å vise noen av de mest brukte modeller og tilhørende diagrammer. For at problemet ikke skal overskygge prinsippene lar vi eksemplet være enkelt. Følgende foreløpige krav til et programvaresystem er identifisert: Det skal lages et system som skal brukes til beregning av areal og omkrets for forskjellige geometriske figurer. Vi begrenser oss til todimensjonale figurer. Når programmet starter skal det komme frem et skjermbilde som viser de typer av figurer som programmet kan utføre beregninger for. Ved å klikke på den aktuelle figuren skal det sprette frem en dialog hvor man kan sette inn nødvendige data for beregningene. Etter at brukeren har klikket på en knapp merket Beregn i dialogen skal programmet gjøre beregningene. Når beregningen er utført skal resultatene vises i et vindu på skjermen. I første omgang skal programmet lages for tre figurer; triangel, rektangel og sirkel. Denne spesifikasjonen er mangelfull. Nye krav vil sannsynligvis bli oppdaget etterhvert som vi modellerer systemet. 1.5.1. Use case modell Vi følger Rational Unified Process (RUP). Da er vi nå i oppstartsfasen og skal se nærmere på kravene til systemet. Et naturlig startpunkt kan være use case. side 8 av 20

Oppstart Detaljering Konstruksjon Overføring 1 2 3 Figur 1 Unified Process Jacobson 1 [1] definerer en use case som en rekke av transaksjoner i en dialog med systemet utført av en instans (bruker) av en aktør. En annen definisjon på use case er: Et sett use case instanser. Hver instans er en serie med aksjoner som systemet utfører og som fører til noe som er nyttig for en aktør. En aktør er en representant for hva som samspiller med systemet. Brukeren er den aktuelle personen som bruker systemet. Aktøren representerer en rolle som brukeren kan spille. Man kan si at en aktør er en klasse, mens en bruker er en instans av denne klassen. Alle use case man kan finne for systemet representerer den samlede funksjonalitet for systemet og er det naturlige startpunkt for å finne klasser og objekter som skal tilby denne funksjonaliteten. Med utgangspunkt i use casene lages mange av de andre modellene av systemet. En måte å finne use casene på er å starte med å identifisere aktører og se på hvilken bruk de vil gjøre av systemet. I dette enkle systemet med beregning av areal og omkrets for geometriske figurer er det antagelig bare en aktør, nemlig den som representerer de som er interessert i arealet og omkretsen av geometriske figurer. Hvilket navn skal vi gi denne aktøren? Jeg foreslår FigurBeregner, i mangel av noe bedre. FigurBeregner er en rolle. Forskjellige personer kan gå inn i den rollen avhengig av hvem som bruker systemet. F.eks kan det være en skoleelev, en student eller en arealplanlegger. Det kan for så vidt også være et annet program som har bruk for denne typen beregninger. Hvilken bruk gjør så FigurBeregner seg av systemet? Hvilken funksjonalitet ønskes? I dette tilfellet det vel ganske enkelt å se at det er BeregningAvArealOgOmkrets. Man kunne tenke seg å dele denne i to use case en for beregning av areal og en for beregning av omkrets. Av og til kan det være en smakssak. For store systemer kan man miste oversikten hvis antallet use case blir stort. Det er ikke problemet her. Jeg velger en use case fordi begge beregningene for de fleste figurer kan utføres med basis i de samme dataene. Da har vi identifisert en aktør, FigurBeregner og en use case, BeregningAvArealOgOmkrets. Vi får følgende enkle us case modell som vis i diagrammet i Figur 2... 1 Jacobsen er den som introduserte use case i objektorientert systemutvikling. Derfor er han referert her. I [7], kapittel 6 gis en grundig beskrivelse av use case. Her skjelner forfatteren mellom forskjellige typer av use case. Egentlig er det samme use case, bare på forskjellig detaljeringsnivå, avhengig av hvor langt man er kommet i utviklingsprosessen. side 9 av 20

BeregningAvArealOgOmkrets Figur 2 FigurBeregner Symbolet for aktøren er en stilisert person og symbolet for en use case er en ellipse. Legg merke til at navnene som er gitt symbolene er skrevet under. Det er i samsvar med Jacobson [1]. Begrunnelsen er at man på den måten ikke får problemer med å få plass til teksten inne i symbolet. Man kan dermed holde en fast størrelse på symbolene. Ikke alle bruker den praksisen, men legger teksten inne i symbolene. Det er heller ikke alle som trekker sammen navnene på den kompakte formen som jeg har gjort. (Larman [7] legger teksten inne i symbolet). Det neste man nå kan gjøre er å utbrodere use casen tekstlig. Det vil si at man beskriver med ord trinn for trinn det som skjer mellom aktøren og systemet i den gitte use case. Slik jeg tolker Jacobson kaller han også denne teksten for use case, mens andre metodikere skiller mellom use case som abstraksjon og dens innhold. Innholdet kalles hos dem scenario [3], [4] eller script. Use case blir hos dem en slags klasse, mens scenariet eller scriptet kan oppfattes som en instans av denne klassen. I den senere tid etter hvert som bruk av use case har blitt mer utbredt, er formaliserte oppsett av use case blitt introdusert. Larman [7] viser eksempler på det. Men en ting synes alle å være enige om. Det er at use case, uavhengig av form, er nyttig og viktig når man skal forstå oppførselen til det systemet som skal utvikles. I denne introduksjonen følger vi Jacobson. Han tar utgangspunkt i kravspesifikasjonen i en eller annen form. Her følger teksten til use casen: side 10 av 20

BeregningAvArealOgOmkrets Programmet starter ved at det kommer opp et skjermbilde som viser en sirkel, et triangel og et rektangel. FigurBeregner klikker på en av figurene. En dialog hvor data kan settes inn spretter frem. Hvis det er en sirkel setter FigurBeregner inn radius, hvis det er rektangel setter FigurBeregner inn bredde og høyde og hvis det er et triangel setter FigurBeregner inn lengden av de tre sidene i tiangelet. FigurBeregner trykker på knappen merket Beregn i dialogen. Programmet vil utføre beregningen av areal og omkrets for den valgte figur. Etter at beregningen er ferdig presenterer programmet resultatet i en dialog. Denne dialogen har en knapp merket OK.FigurBeregner klikker OK og programmet viser skjermbildet med de tre figurene igjen. FigurBeregner kan da få utført nye beregninger. Hvis ikke kan FigurBeregner avslutte programmet. I tilknytning til denne use casen kan det også være hensiktsmessig å lage en prototype som viser brukergrensesnittet. side 11 av 20

side 12 av 20

Dette er en prototype. Det endelige brukergrensesnittet behøver ikke se slik ut. Poenget er å komme frem til enighet om det som skal skje i dialog med brukeren. 1.5.2. Domenemodellen Use case modellen viser en side ved det systemet som skal utvikles den eksterne funksjonaliteten. Denne modellen skal hjelpe til med å finne frem til hvilket ansvar som skal legges til objekter i programvaren. Men før man arbeider videre med use casene, kan det være nyttig å modellere den virkelige verden knyttet til det problemet som skal løses. Dermed kommer en annen side ved systemet frem. Denne siden vil vise objekter og sammenhenger som er typiske for problemområdet. Disse objektene vil delvis finnes igjen som programvareobjekter i det endelige programmet. Denne modellen av virkeligheten, kalles gjerne problemdomenemodellen [1], [5]. Et annet nav er den konseptuelle modellen [7]. Den vil vises som et klassediagram. I vårt enkle eksempel er det umiddelbart flere kandidatobjekter som dukker opp: - geometrisk figur - sirkel - triangel - rektangel Disse er beslektede. Et første utkast til domenemodell blir derfor et hierarki med geometrisk figur som superklasse og som besitter alle felles egenskaper for alle typer geometriske figurer. GeomtriskFigur Sirkel Rektangel Triangel Figur 3 Figur 3 viser domenemodellen på sitt høyeste abstraksjonsnivå. Klassene er rektangler med navnene skrevet inni rektanglene. I superklassen er navnet skrevet i kursiv. Det forteller at klassen er abstrakt. Det vil si det ikke vil eksistere noen instanser av denne klassen. De konkrete klassene er Sirkel, Rektangel og Triangel. (Egentlig er det bare de konkrete klassene som tilhører problemdomenet. Abstrakte klasser tilhører programvaren). Disse vil det kunne opprettes instanser av i et program. Trekanten som peker mot klassen på toppen i hierarkiet er en diskriminator som forteller at vi har en generalisering/spesialisering, dvs et arvehierarki. Strengt talt har vi gått litt lenger enn å modellere det rene problemdomenet. Dette fordi vi tenderer i retning av programvareklasser ved introduksjon av abstrakte klasser. Men det falt naturlig. Legg merke til at vi er opptatt av konseptene (den virkelige verden) og ikke operasjoner og attributter som tilhører programvareklasser. I problemdomenemodellen er det ellers vanlig å trekke inn noen attributter som er naturlige for å få frem de som er essensielt med et objekt i den virkelige verden. Legg dessuten merke til at problemdomenemodellen er side 13 av 20

en klassemodell, mens det man snakker om er objekter (også kalt konsepter) i den virkelige verden 2. UML gjør det mulig å lage modeller hvor vi kan legge inn informasjon etter behov. Forskjellige interessenter kan være interessert i forskjellige detaljer i systemet. Brukere er vanligvis opptatt av oversikten, mens designere og testere trenger detaljert informasjon. Vi kan detaljere modellen med attributter og opersjoner for klassene. Da er vi i ferd med å lage en modell med programvareklasser. I den abstrakte klassen legger vi attributter og operasjoner som er felles for alle klassene i hierarkiet. Alle geometriske figurer har et areal og en omkrets. Hvordan disse beregnes vil være forskjellig. Operasjonene har samme navn, men implementasjonen vil være forskjellig i de ulike subklassene 3. Det er dette som kalles polymorfisme. GeomtriskFigur areal beregnareal() beregnomkrets() hentarealet() Sirkel Rektangel Triangel radius høyde bredde sideen sideto beregnareal() beregnomkrets() settradius(radius) hentradius() beregnareal() beregnomkrets() setthøyde(høyde) settbredde(bredde) henthøyde() beregnareal() beregnomkrets() settsider(sideen, sideto, sidetre) Figur 4 Figur 4 viser det samme diagrammet, men nå med flere detaljer. Det er lagt inn de attributter og operasjoner som er mest åpenbare. Etter hvert som man arbeider videre mot realisering av 2 I [7] kapittel 1 finner man en introduksjon til begrepene og i kapittel 9 flere detaljer. 3 En operasjon som ikke har noen implementasjon i den abstrakte klassen kalles i C++ for en ren virtuell funksjon, i Java en abstrakt metode. side 14 av 20

klassen kan man legge inn enda flere detaljer. Det skal vi komme tilbake til. Vi skal senere se på mer systematiske måter å komme frem til operasjoner og attributter på. Klasse navn Sirkel attributt:type = initialverdi radius:float = 1 operasjon(arg liste):retur type beregnareal() beregnomkrets() settradius(radius:float) hentradius():float (a) (b) Figur 5 Figur 5 viser hvordan en detaljert spesifikasjon av attributter og operasjoner kan gjøres. Til venstre vises den generelle oppbygning. Til høyre har vi et konkret eksempel. 1.5.3. Analysemodellen Domenemodellen vil ikke være den modellen som uttrykker designet av programvaresystemet. Det er det designmodellen som skal gjøre. Den vil inneholde de klasser som skal gjøre jobben i programmet. Men før man kommer så langt vil man lage en analysemodell. Dette er en logisk modell som viser hva programmet skal gjøre, mens designmodellen viser konkret hvordan vi vil gjøre det. Analysemodellen er uavhengig av implementasjonsmiljøet. Designmodellen tar hensyn til implementasjonsmiljøet [1]. I objektorientert systemutvikling er grensen mellom analyse og design ganske flytende. Davis [6] skriver om det han kaller what versus how dilemmaet. En persons hvordan er en annen persons hva. Analysemodellen er i stor grad også hvordan fordi det er her man finner klassene og hvordan de skal samspille i programmet. Det betyr at man fastlegger den overordnede arkitekturen og dermed strukturen i programmet. Dette er i høy grad hvordan. På den annen side sier analysemodellen hva programmet skal bestå av ikke hvordan den detaljerte realiseringen skal gjøres. Det overlates til design og implementasjon som til sammen utgjør konstruksjonen av systemet. Da er vi over i konstruksjonsfasen. Tilbake til analysen og analysemodellen. For å utvikle et komplett program er ikke domenemodellen nok. Domenemodellen bygges for at vi skal forstå problemområdet. Det er ikke gitt at noen av klassene i domenemodellen gjenfinnes i det ferdige programmet. Men det er sjeldent. Use case modellen og domenemodellen danner utgangspunktet for analysemodellen. Det vil også være fornuftig å se på eksisterende mønstre for god analyse og design. Vi skal lage et interaktivt program. Et mønster for et slikt program er Model View Controller (MVC) kjent fra SmallTalk. Se Figur 6 side 15 av 20

Model Controller View Figur 6 Modell representerer dataene og kunnskapen i programmet. View er brukergrensesnittet. Controller binder programmet sammen. Jacobson [1] definerer tre typer av objekter grensesnittobjekt, entitetsobjekt og kontrollobjekt. Han hadde egne symboler for disse. I UML kan man bruke stereotyper for å skille mellom typer av klasser eller objekter. Modell er typisk et eller flere entitetsobjekter. View er et eller flere grensesnittobjekter. Controller er et eller flere kontrollobjekter. En gruppering av klasser som logisk hører sammen og som utgjør en større enhet, modelleres som pakker i UML. En pakke har et eget grafisk symbol. MVC modellen kunne derfor også vært vist som i Figur 7. Model Controller View Figur 7 Pilene representerer assosiasjoner mellom klassene (pakkene). Pilene viser retningen på assosiasjonene. F.eks så ser Controller Model, mens Modell ikke har behov for å kjenne til Controller. Vi bruker dette mønsteret i vårt program. Da blir analysemodell som i Figur 8 side 16 av 20

SirkelDialog Beregner View RektDialog TriangDialog GeomFigur RersultatDialog Figur 8 Sirkel Rektangel Triangel 1.5.4. Designmodellen Vi er nå etterhvert over i konstruksjonsfasen. En av de første tingene vi gjør i denne fasen er å designe use casene. Vi skal se på det detaljerte samspill mellom objektene i programmet. Hjelpemidler er interaksjonsdiagrammer. Det er to typer interaksjonsdiagrammer sekvensdiagrammer og samarbeidsdiagrammer. Et sekvensdiagram viser rekkefølgen av hendelser i en use case. Sekvensdiagrammer var sentrale hos Jacobson [1]. Han kaller dem faktisk interaksjonsdiagrammer. Rumbaugh [3] hadde noe lignende som han kalte event trace. Ideene er tatt med i UML under betegnelsen sekvensdiagram. side 17 av 20

Start hovedvindu vises while flereberegninger FigurBeregner klikker på fiur Programmet viser dialog FigurBeregner setter inn data FigurBeregner klikker OK Dialog tar vare på data Beregning utføres start klikkfigur() settdata OK :Beregner :GeomFigur :View :Dialog :Resultat visview() hentdata() settdata() beregnareal() beregnomkrets() hentareal() hentomkrets() visdialog() hentdata() hentdata() Resultat vises i dialog FigurBeregner klikker OK endwhile slutt slutt OK visresultat(resultat) visdialog() visresultat() Figur 9 Figur 9 er et eksempel på et sekvensdiagram. En av hensiktene med diagrammet er at det skal være til hjelp når man skal fordele og finne frem til operasjoner for de forskjellige objekter som inngår i en use case. Diagrammer viser også rekkefølgen av operasjonene. Diagrammet kan også brukes til å vurdere godheten av en løsning. La oss se på oppbygningen av diagrammet. Helt til venstre er use casen formulert i pseudokode. Øverst er tegnet inn de objekter som inngår i use casen inkludert aktøren 4. De er i dette tilfelle anonyme objekter fordi bare klassenavnet er angitt. Dialogobjektet representerer alle de dialoger som brukes for å lese inn data for forskjellige figurer. Det er gjort for å lette oversikten. Det gjør det også lettere senere å utvide programmet med flere typer figurer uten at diagrammet må endres. Det betyr at 4 Vi har brukt et annet symbol for aktøren i dette tilfellet. Det er tillatt i UML. Man kan legge inn egne symboler for å gjøre en modell rikere. side 18 av 20

operasjonene på dette objektet må betraktes som generiske. Det samme er tilfellet med figurobjektet. De stiplede vertikale linjene er såkalte livslinjer for objektene og representerer en tidsdimensjon uten å angi en tidsskala. De horisontale pilene representerer meldinger som et objekt sender til et annet. Teksten over pilene er de operasjoner som utløses som svar på disse meldingene. Et objekt kan sende melding til seg selv. Et samarbeidsdiagram viser den samme informasjon i en annen dimensjon. Figur 10 viser et samarbeidsdiagram for eksemplet vårt. Eksemplet er selvforklarende. Det dreier seg om samspill mellom objekter. Piler viser retningen på meldingsutvekslingen. Teksten over pilene er navn på operasjoner. Tallet foran operasjonen angir rekkefølgen. 16:visDialog 17:visResultat :Resultat 2:visView 9:hentData 15:visResultat :View 7:hentData 4:visDialog 8:hentData :Dialog 5:settData 3:klikkFigur 6:OK 18:OK :Beregner 1:start 19:slutt 10:settData 11:beregnAreal 12:beregnOmkrets 13:hentAreal 14:hentOmkrets :Figur Figur 10 1.6. Sluttkommentar til denne leksjonen. Vi har i denne leksjonen tatt for oss modeller og nytten av å modellere. Det er gjort et raskt sveip innom noen av de mest sentrale modeller som vi lager i objektorientert systemutvikling. UML som modelleringsspråk er introdusert. Men vi har vært litt overfladiske i beskrivelsen av hvordan vi finner frem til klasser og objekter, hvilke faser vi er i, og hvordan objekter skal spille sammen for å realisere et godt programvaresystem. Poenget med dette faget er å introdusere mer systematiske måter å gjøre dette på. Det vil derfor være tema i senere leksjoner. side 19 av 20

1.7. Referanser 1. Grady Booch, James Rumbaugh, Ivar Jacobson, The Unified Modeling Language User s Guide, Addison-Wesley 1998, ISBN 0-201-57168-4 2. Ivar Jacobson med flere, Object-Oriented Software Engineering, A Use Case Driven Approach, Addison-Wesley 1992, ISBN 0-201-54435. 3. James Rumbaugh med flere, Object-Oriented Modelling and Design, Prentice Hall 1991, ISBN 0-13-630054-5 4. Paul Allen & Stuart Frost, Component-Based Development for Enterprise Systems, Cambridge University Press 1998, ISBN 0-521-64999-4 5. Martin Fowler, UML Destilled, Applying the Standard Object Modelling Language, Addison-Wesley 1997, ISBN 0-201-32563-2 6. Alan M. Davis, Software Requirements, Analysis & Specification, Prentice Hall 1990, ISBN 0-13-824814-1 7. Craig Larman, Applying UML And Patterns, An Introduction to Object-Oriented Analysis and Design and the Unified Process, 2.utgave, Prentice Hall 2002, ISBN 0-13-092569-1 side 20 av 20