GRASP (objektově orientovaný design) - GRASP (object-oriented design)
Tento článek obsahuje seznam obecných Reference, ale zůstává z velké části neověřený, protože postrádá dostatečné odpovídající vložené citace.Květen 2015) (Zjistěte, jak a kdy odstranit tuto zprávu šablony) ( |
tento článek příliš spoléhá na Reference na primární zdroje.Květen 2015) (Zjistěte, jak a kdy odstranit tuto zprávu šablony) ( |
Softwarové vzory pro přiřazení obecné odpovědnosti (nebo Zásady), zkráceně UCHOPIT, skládají se z pokynů pro přiřazení odpovědnosti třídám a objektům v objektově orientovaný design.[1] To nesouvisí s PEVNÝ princip návrhu.
Různé vzory a principy používané v GRASP jsou kontrolor, tvůrce, nepřátelství, informační expert, nízký spojka, vysoká soudržnost, polymorfismus, chráněné varianty a čistá výroba. Všechny tyto vzorce na některé odpovídají software problémy a tyto problémy jsou společné téměř každému vývoj softwaru projekt. Tyto techniky nebyly vynalezeny proto, aby vytvářely nové způsoby práce, ale aby lépe dokumentovaly a standardizovaly staré, osvědčené programování principy v objektově orientovaném designu.
Počítačový vědec Craig Larman uvádí, že „kritickým návrhovým nástrojem pro vývoj softwaru je mysl dobře vzdělaná v principech designu UML nebo jakoukoli jinou technologii. “[2] GRASP jsou tedy skutečně mentální sadou nástrojů, učební pomůckou, která pomáhá při navrhování objektově orientovaného softwaru.
Vzory
V designu OO (Object Oriented) je vzor pojmenovaným popisem problému a řešení, které lze použít v nových kontextech; v ideálním případě nám vzor poradí, jak použít jeho řešení za různých okolností, a vezme v úvahu síly a kompromisy. Při přiřazování odpovědnosti k předmětům se řídí mnoho vzorů, vzhledem ke konkrétní kategorii problému.
Informační expert
Problém: Jaký je základní princip, podle kterého lze přiřadit odpovědnost objektům?
Řešení: Přiřaďte odpovědnost třídě, která má informace potřebné k jejímu splnění.
Informační expert (taky expert nebo expertní princip) je princip používaný k určení, kam delegovat odpovědnosti, jako jsou metody, vypočítaná pole atd.
Pomocí principu informačního odborníka je obecným přístupem k přiřazení odpovědnosti pohled na danou odpovědnost, určení informací potřebných k jejímu splnění a poté určení, kde jsou tyto informace uloženy.
To povede k zařazení odpovědnosti na třídu s největším počtem informací potřebných k jejímu splnění.[3]
Související vzor nebo princip: Nízké propojení, vysoká soudržnost
Tvůrce
Vytváření objektů je jednou z nejběžnějších činností v objektově orientovaném systému. Která třída je zodpovědná za vytváření objektů, je základní vlastností vztahu mezi objekty konkrétních tříd.
Problém: Kdo vytvoří objekt A?
Řešení: Obecně přiřadit třídu B
odpovědnost za vytvoření objektu A
pokud platí jedna nebo nejlépe více z následujících možností:
- Případy
B
obsahovat nebo složit agregované instanceA
- Případy
B
zaznamenávat instanceA
- Případy
B
úzce používat instanceA
- Případy
B
mít inicializační informace pro instanceA
a předat to tvorbě.[4]
Související vzor nebo princip: Nízká spojka, Tovární vzor
Ovladač
The ovladač model přiřazuje odpovědnost za řešení systémových událostíUI třída, která představuje celkový systém nebo a případ použití scénář. Objekt řadiče je objekt bez uživatelského rozhraní odpovědný za příjem nebo zpracování systémové události.
Problém: Kdo by měl být odpovědný za zpracování události vstupního systému?
Řešení: K řešení by měl být použit řadič případu použití Všechno systémové události případu použití a lze je použít pro více než jeden případ použití. Například pro případy použití Vytvořit uživatele a Odstranit uživatele, jeden může mít jednu třídu s názvem UserController, místo dvou samostatných řadičů případů použití.
Řadič je definován jako první objekt mimo vrstvu uživatelského rozhraní, který přijímá a koordinuje („řídí“) operaci systému. Správce by měl delegovat práci, kterou je třeba udělat, na jiné objekty; koordinuje nebo řídí aktivitu. Samotné by to nemělo dělat moc. Ovladač GRASP lze považovat za součást vrstvy aplikace / služby[5] (za předpokladu, že aplikace výslovně rozlišuje mezi vrstvou aplikace / služby a vrstva domény ) v objektově orientovaném systému se společnými vrstvami v logické architektuře informačního systému.
Související vzor nebo princip: Příkaz, Fasáda, Vrstvy Čistá výroba
Indirection
Indirection pattern podporuje nízkou vazbu a znovu využívá potenciál mezi dvěma prvky přiřazením odpovědnosti za mediaci mezi nimi prostřednímu objektu. Příkladem toho je zavedení komponenty řadiče pro zprostředkování mezi daty (model) a jeho reprezentací (pohled) ve vzorci řízení modelu. Tím je zajištěno, že vazba mezi nimi zůstane nízká.
Problém: Kam přiřadit odpovědnost, aby se zabránilo přímému spojení mezi dvěma (nebo více) věcmi? Jak oddělit objekty tak, aby byla podporována nízká vazba a potenciál opětovného použití zůstal vyšší?
Řešení: Přiřaďte zprostředkujícímu objektu odpovědnost za zprostředkování mezi ostatními komponentami nebo službami tak, aby nebyly přímo spojeny.
Zprostředkovatel vytvoří indirection mezi ostatními složkami.
Nízká spojka
Spojení je měřítkem toho, jak silně je jeden prvek spojen s jinými prvky, má o nich znalosti nebo na ně spoléhá. Nízká spojka je hodnotící vzor, který určuje, jak rozdělit odpovědnost za následující výhody:
- nižší závislost mezi třídami,
- změna v jedné třídě s menším dopadem na jiné třídy,
- vyšší potenciál opětovného použití.
Vysoká soudržnost
Vysoká soudržnost je hodnotící vzorec, který se snaží udržet objekty vhodně zaměřené, zvládnutelné a srozumitelné. Vysoká soudržnost se obvykle používá na podporu nízké spojky. Vysoká soudržnost znamená, že odpovědnosti daného prvku jsou silně příbuzné a vysoce zaměřené. Rozdělení programů do tříd a subsystémů je příkladem aktivit, které zvyšují soudržné vlastnosti systému. Alternativně je nízká soudržnost situací, ve které má daný prvek příliš mnoho nesouvisejících povinností. Prvky s nízkou soudržností často trpí tím, že je těžké je pochopit, znovu použít, udržovat a měnit.[6]
Polymorfismus
Podle polymorfismus principu je odpovědnost za definici variace chování na základě typu přiřazena typu, u kterého k této variantě dochází. Toho je dosaženo pomocí polymorfní operace. Uživatel typu by měl použít polymorfní operace namísto explicitního větvení podle typu.
Problém: Jak zacházet s alternativami podle typu? Jak vytvořit zásuvné softwarové komponenty?
Řešení: Pokud se související alternativy nebo chování liší podle typu (třídy), přiřaďte odpovědnost za chování - pomocí polymorfních operací - typům, u nichž se chování liší. (Polymorfismus má několik souvisejících významů. V této souvislosti to znamená „přiřazení stejného názvu službám v různých objektech“.)
Chráněné varianty
The chráněné varianty pattern chrání prvky před variacemi na jiné prvky (objekty, systémy, subsystémy) zabalením ohniska nestability znakem rozhraní a pomocí polymorfismus k vytvoření různých implementací tohoto rozhraní.
Problém: Jak navrhovat objekty, subsystémy a systémy tak, aby variace nebo nestabilita v těchto prvcích neměly nežádoucí dopad na jiné prvky?
Řešení: Určete body predikované variace nebo nestability; přidělit odpovědnosti a vytvořit kolem nich stabilní rozhraní.
Čistá výroba
A čistá výroba je třída, která nepředstavuje koncept v problémové oblasti, speciálně vytvořený pro dosažení nízké vazby, vysoké soudržnosti a odvozeného potenciálu opětovného použití (když řešení předložené informační expert vzor není). Tento druh třídy se v systému nazývá „služba“ design řízený doménou.
Související vzory a zásady• Nízká vazba • Vysoká soudržnost.
Viz také
- Anemický model domény
- Návrhový vzor (informatika)
- Designové vzory (kniha)
- SOLID (objektově orientovaný design)
Poznámky
- ^ https://dzone.com/articles/solid-grasp-and-other-basic-principles-of-object-o
- ^ Larman 2005, str. 272.
- ^ Larman 2005 kapitola 17, část 11.
- ^ Larman 2005 kapitola 16, sekce 16.7
- ^ „Aplikační vrstva jako obchodní fasáda?“. Yahoo! Skupiny (domaindrivendesign). Citováno 15. července 2010.
- ^ Larman 2005, str. 314–315.
Reference
- Larman, Craig (2005) [2004]. Aplikování UML a vzorů - Úvod do objektově orientované analýzy a designu a iteračního vývoje (3. vyd.). New Jersey: Prentice Hall. ISBN 0-13-148906-2.CS1 maint: ref = harv (odkaz)