Abstrakce (abstraktní typy a rozhraní)
Poznámka:
Tento obsah je znovu vytištěn oprávněním Pearson Education, Inc. z Framework Design Guidelines: Conventions, Idioms a Patterns for Reusable .NET Libraries, 2. vydání. Tato edice byla publikována v roce 2008 a kniha byla od té doby plně upravena ve třetím vydání. Některé informace na této stránce můžou být zastaralé.
Abstrakce je typ, který popisuje kontrakt, ale neposkytuje úplnou implementaci kontraktu. Abstrakce se obvykle implementují jako abstraktní třídy nebo rozhraní a mají dobře definovanou sadu referenční dokumentace popisující požadovanou sémantiku typů implementujících kontrakt. Mezi nejdůležitější abstrakce v rozhraní .NET Framework patří Stream, IEnumerable<T>a Object.
Architektury můžete rozšířit implementací konkrétního typu, který podporuje kontrakt abstrakce a použití tohoto konkrétního typu s rozhraními API architektury, které abstrakci využívají (pracují s) abstrakcí.
Smysluplný a užitečný abstrakce, který je schopen odolat testu času, je velmi obtížné navrhnout. Hlavními potížemi je získání správné sady členů, už ne a ne méně. Pokud má abstrakce příliš mnoho členů, stává se obtížné nebo dokonce nemožné implementovat. Pokud má pro slíbenou funkci příliš málo členů, stane se v mnoha zajímavých scénářích zbytečné.
Příliš mnoho abstrakcí v rámci také negativně ovlivňuje použitelnost architektury. Často je poměrně obtížné pochopit abstrakci, aniž byste porozuměli tomu, jak zapadá do širšího obrazu konkrétních implementací a rozhraní API, která pracují na abstrakci. Také názvy abstrakcí a jejich členů jsou nutně abstraktní, což často z nich dělá kryptografickou a neschválitelnou, aniž byste nejprve porozuměli širšímu kontextu jejich použití.
Abstrakce však poskytují extrémně výkonnou rozšiřitelnost, kterou ostatní mechanismy rozšiřitelnosti často neodpovídají. Jsou jádrem mnoha architektur, jako jsou moduly plug-in, inverze řízení (IoC), kanály atd. Jsou také velmi důležité pro testovatelnost architektur. Dobré abstrakce umožňují zatěžovat náročné závislosti pro účely testování jednotek. V souhrnu jsou abstrakce zodpovědné za vyhledávanou bohatost moderních objektově orientovaných architektur.
❌ NEPOSKYTUJTE abstrakce, pokud nejsou testovány vývojem několika konkrétních implementací a rozhraní API, které abstrakce využívají.
✔️ Při návrhu abstrakce vybírejte pečlivě mezi abstraktní třídou a rozhraním.
✔️ ZVAŽTE poskytnutí referenčních testů pro konkrétní implementace abstrakcí. Tyto testy by měly uživatelům umožnit otestovat, zda jejich implementace správně implementují kontrakt.
© Části 2005, 2009 Microsoft Corporation. Všechna práva vyhrazena.
Reprinted by permission of Pearson Education, Inc. from Framework Design Guidelines: Conventions, Idioms, and Patterns for Reusable .NET Libraries, 2nd Edition by Krzysztof Cwalina and Brad Abrams, published Oct 22, 2008 by Addison-Wesley Professional v rámci Microsoft Windows Development Series.