Use Case
 
StartSeite | Neues | TestSeite | ForumSeite | Teilnehmer | Kategorien | Index | Hilfe | Einstellungen | Ändern

Use Case

UseCase ist ein Begriff der Objektorientierten Analyse, der mit Anwendungsfall nur sehr unzureichend übersetzt ist. IvarJacobson? definiert einen UseCase als ein Szenario, das damit beginnt, dass ein Anweder eines Systems eine Transaktion oder eine Folge von zusammenhängenden Ereignissen auslöst.

Der Nutzen einer Analyse, die auf solchen Szenarien beruht, liegt zuerst einmal darin, dass durch die Szenarien ein Gerüst vorgegeben ist. Es ist möglich, sich schon bei der Anforderungsanalyse an solchen Anwendungsfällen entlangzuhangeln. Damit ist bei einem Gespräch zwischen Benutzern, Fachleuten aus dem Anwendungsbereich und Entwicklern ein Rahmen für das gesteckt, um was es bei diesem Gespräch gehen soll.

Eine Methode zum Auffinden von solchen Szenarien bietet die hierarchische Aufgabengliederung (REFA). Dabei wird der Zweck eines Systems in einem einfachen Satz (mit 'einem' Verb) formuliert. Die so formulierte Aufgabe des Systems wird dann schrittweise in Teilaufgaben zerlegt. Immer dann, wenn solchen Teilaufgaben in einer bestimmten Reihenfolge ablaufen müssen, ist deren Vorgänger-Knoten im Aufgabenbaum ein erster Kandidat für ein Szenario (und die Verfeinerung in Teilaufgaben ist vermutlich nicht sachlich gerechtfertigt).

Jeder UseCase hat einen oder mehrere Abläufe, die die Grundlage für die Beschreibung der Arbeitsweise eines Softwaresystems bilden.

Bei der objektorientierten Analyse werden die Szenarien oder UseCases oft nicht nur aufgezählt. Auch Vererbungsbeziehungen und Komposition zwischen UseCases werden betrachtet.

Weil ein UseCase in der objektorientierten Analyse ein Szenario in Form einer Abfolge von Aktivitäten und einer Zusammenarbeit zwischen Benutzern und Objekten des Systems darstellt, findet sich ein Abbild der Vererbung von UseCases normalerweise nicht in der Vererbungshierarchie des entworfenen Systems.

Die Komposition von UseCases geschieht, indem andere UseCases entweder auf eine im zusammengesetzten UseCase vorgesehene Art und Weise oder durch nachträgliche Erweiterung von vorhandenen UseCases zusammengefügt werden. Zumindest der erste Fall kann im entworfenen System durch das StrategyPattern abgebildet werden.

Diskussion

MatthiasBohlen provoziert mal ein wenig: (Kommentare willkommen)

Zudem geht es bei UseCases um das Problem, während das Design die Lösung für das Problem abbildet. Eine allgemein gültige mechanische Transformation vom einen zum anderen gibt es nicht.

Matthias, Du sprichst mir voll aus dem Herzen. Ich habe erst wenige UseCaseDiagramme? gesehen, aber diese waren sämtlich vollkommen unnütz (und von den Erstellern ganz offenbar nur erstellt worden "weil man das eben macht"). Und das eine, an dessen Entstehung ich mit beteiligt war, hat lediglich zu verwirrten Diskussionen über die Notation geführt aber zu keinerlei neuen Erkenntnissen über das System, möchte ich behaupten... -- IljaPreuß

Im InformatikStudium an der TU Wien gibt es eine sehr interessante zwei-semestrige Veranstaltung zu SoftwareEngineering?, in der unter anderem UseCaseDiagramme? gebracht werden. In den Gruppen wo ich war (insgesamt ca. 10 Leute) hat keiner <<extends>> kapiert oder beschreiben (inklusive den Tutoren). Außerdem wird das Diagramm ab 10 "Eiern" Sowieso so unübersichtlich, daß eine tabellarische Darstellung mit primären und sekundären Vorgangen wahrscheinlich geeigneter wäre. --DavidSchmitt

Die grafische Darstellung im Diagramm ist wirklich recht zweifelhaft. Lediglich die Navigation in Tools wird dadurch vereinfacht. Vererbungsbeziehungen verwende ich bei einem Use|Case auch nicht, aber bei Akteuren. Insbesondere wenn es darum geht Rollen zu modellieren. -- BerndEckenfels

Zur Vererbung: ich finde schon, dass der UseCase "Einkaufen beim Gemüsehändler" ein spezieller UseCase "Einkaufen beim Einzelhändler" ist. -- PitHauge

Ressourcen


StartSeite | Neues | TestSeite | ForumSeite | Teilnehmer | Kategorien | Index | Hilfe | Einstellungen | Ändern
Text dieser Seite ändern (zuletzt geändert: 13. Mai 2011 14:27 (diff))
Suchbegriff: gesucht wird
im Titel
im Text