Princip substituce Liskov - Liskov substitution principle

Nahraditelnost je princip v objektově orientované programování s uvedením, že v a počítačový program, pokud S je a podtyp z T, pak objekty typ T může být vyměnit s objekty typu S (tj. objekt typu T může být nahrazeno s jakýmkoli objektem podtypu S) beze změny žádaných požadovaných vlastností programu (správnost, provedený úkol atd.). Formálnější je Princip substituce Liskov (LSP) je konkrétní definice vztahu podtypů, zvaná (silný) podtyp chování, který původně představil Barbara Liskov na konferenci v roce 1987 hlavní přednáška adresa s názvem Abstrakce dat a hierarchie. Je to sémantický spíše než pouze syntaktický vztah, protože má v úmyslu zaručit sémantickou interoperabilitu typy v hierarchii zejména typy objektů. Barbara Liskov a Jeannette Wing popsal princip stručně v dokumentu z roku 1994 takto:[1]

Požadavek na podtyp: Nechte být prokazatelnou vlastností předmětů typu T. Pak by mělo platit pro objekty typu S kde S je podtyp T.

Ve stejné práci Liskov a Wing podrobně popsali svůj pojem behaviorálního podtypu v rozšíření Logika hoare, který má určitou podobnost s Bertrand Meyer je design podle smlouvy v tom, že bere v úvahu interakci podtypů s předpoklady, dodatečné podmínky a invarianty.

Zásada

Liskovova představa o podtypu chování definuje pojem zaměnitelnosti za objekty; to je, pokud S je podtyp T, pak objekty typu T v programu lze nahradit objekty typu S aniž by se měnila některá z požadovaných vlastností tohoto programu (např. správnost ).

Podtypování na základě chování je silnější představa než obvyklá podtypování funkcí definováno v teorie typů, který se spoléhá pouze na rozpor typů argumentů a kovariance návratového typu. Podtypování na základě chování je nerozhodnutelný obecně: pokud q je metoda "vlastnost" pro X vždy končí ", pak je nemožné, aby program (např. kompilátor) ověřil, že pro některý podtyp platí S z T, i kdyby q platí pro T. Princip je nicméně užitečný při úvahách o návrhu hierarchií tříd.

Liskovův princip ukládá některé standardní požadavky podpisy které byly přijaty v novějších objektově orientovaných programovacích jazycích (obvykle spíše na úrovni tříd než typů; viz nominální vs. strukturální subtypizace pro rozlišení):

  • Rozporuplnost argumentů metody v podtypu.
  • Kovariance návratových typů v podtypu.
  • Metody podtypu by neměly být vyvolávány žádné nové výjimky, kromě případů, kdy jsou tyto výjimky samy o sobě podtypy výjimek vyvolávaných metodami supertypu.

Kromě požadavků na podpis musí podtyp splňovat řadu podmínek chování. Ty jsou podrobně popsány v terminologii připomínající terminologii design podle smlouvy metodologie, což vede k určitým omezením, jak mohou smlouvy interagovat dědictví:

  • Předpoklady nelze v podtypu posílit.
  • Postkondice nemohou být oslabeny v podtypu.
  • Invarianty supertypu musí být zachovány v podtypu.
  • Omezení historie („pravidlo historie“). Objekty jsou považovány za modifikovatelné pouze pomocí jejich metod (zapouzdření ). Protože podtypy mohou zavádět metody, které nejsou v supertypu, zavedení těchto metod může umožnit změny stavu v podtypu, které nejsou v supertypu přípustné. Omezení historie to zakazuje. Byl to nový prvek představený Liskovem a Wingem. Porušení tohoto omezení lze ilustrovat definováním a proměnlivý bod jako podtyp neměnný bod. Jedná se o porušení historického omezení, protože v historii EU neměnný bod, stav je po vytvoření vždy stejný, takže nemůže zahrnovat historii a proměnlivý bod obecně. Pole přidaná k podtypu však mohou být bezpečně upravena, protože je nelze pozorovat pomocí metod supertypu. Lze tedy odvodit kruh s pevným středem, ale proměnlivým poloměrem z neměnný bod bez porušení LSP.

Počátky

Pravidla pro pre- a postconditions jsou totožná s pravidly, která zavedl Bertrand Meyer ve své knize z roku 1988 Objektově orientovaná konstrukce softwaru. Jak Meyer, tak později Pierre America, který tento termín použil jako první podtyp chování, dal důkazní teoretik definice některých pojmů podtypů chování, ale jejich definice nepřihlížely aliasing které se mohou vyskytnout v programovacích jazycích, které podporují odkazy nebo ukazatele. Přihlédnutí k aliasingu bylo hlavním zlepšením provedeným Liskovem a Wingem (1994) a klíčovou ingrediencí je historické omezení. Podle definic Meyera a Ameriky by MutablePoint byl podtypem chování ImmutablePoint, zatímco LSP to zakazuje.

Kritika

I když je široce používán, charakterizace podtyp chování protože se říká, že schopnost nahradit objekty podtypu objekty supertypu je chybná. Nezmiňuje se o tom Specifikace, takže vyzývá k nesprávnému čtení, kde implementace supertypu se porovnává s implementace podtypu. To je problematické z několika důvodů, jedním z nich je, že nepodporuje běžný případ, kdy je supertyp abstraktní a nemá žádnou implementaci. Jemněji také v kontextu objektově orientovaného imperativního programování je obtížné přesně definovat, co to znamená univerzálně nebo existenciálně kvantifikovat přes objekty daného typu, nebo nahradit jeden objekt jiným.[2] Když aplikujeme podtyp, obecně nenahrazujeme objekty podtypu objekty supertypu, jednoduše používáme objekty podtypu jako objekty supertypu. To znamená, že jsou to stejné objekty, podtypové objekty, které jsou také objekty supertypu.

V rozhovoru v roce 2016 Liskov sama vysvětluje, že to, co uvedla ve svém hlavním projevu, bylo „neformální pravidlo“, že Jeannette Wing později navrhla, aby se „pokusili přesně zjistit, co to znamená“, což vedlo k jejich společnému zveřejnění[1] o behaviorálním podtypování, a skutečně, že „technicky se tomu říká behaviorální podtypování“.[3] Během rozhovoru nepoužívá k diskusi o pojmech substituční terminologii.

Viz také

Reference

  1. ^ A b Liskov, Barbara; Wing, Jeannette (01.11.1994). "Behaviorální pojem subtypizace". Transakce ACM v programovacích jazycích a systémech. 16 (6): 1811–1841. doi:10.1145/197320.197383. S2CID  999172.
  2. ^ Leavens, Gary T .; Naumann, David A. (srpen 2015). „Podtypování na základě chování, dědičnost specifikací a modulární uvažování“. Transakce ACM v programovacích jazycích a systémech. 37 (4): 1–88. doi:10.1145/2766446. S2CID  1379166.
  3. ^ van Vleck, Tom (20. dubna 2016). Rozhovor s Barbarou Liskovovou. ACM.

Bibliografie

Obecné odkazy

  • Gary T. Leavens a Krišna K. Dhara, Koncepty behaviorálního podtypování a náčrt jejich rozšíření na systémy komponentních bází v Gary T. Leavens, Murali Sitaraman, (ed.) Základy systémů založených na komponentách, Cambridge University Press, 2000 ISBN  0-521-77164-1. Tento článek zkoumá různé představy o podtypech chování, včetně Liskov a Wing's.
  • Liskov, B. H.; Wing, J. M. (Listopad 1994). Behaviorální pojem subtypizace. ACM Trans. Program. Lang. Syst. 16 (6). 1811–1841. doi:10.1145/197320.197383. Aktualizovaná verze se objevila jako technická zpráva CMU: Liskov, Barbara; Wing, Jeannette (Červenec 1999). „Behaviorální podtypování pomocí invariantů a omezení“ (PS ). Citováno 2006-10-05. Formalizace principu jeho autory.
  • Reinhold Plösch, Smlouvy, scénáře a prototypy: integrovaný přístup k vysoce kvalitnímu softwaruSpringer, 2004, ISBN  3-540-43486-0. Obsahuje jemnější úvod do podtypů chování v různých formách v kapitole 2.
  • Robert C. Martin, Princip střídání Liskov Zpráva C ++, březen 1996. Článek populární v komunitě objektově orientovaného programování, který uvádí několik příkladů porušení LSP.
  • Kazimir Majorinc, Ellipse-Circle Dilemma and Inverse Inheritance, ITI 98, Proceedings of the 20. International Conference of Information Technology Interfaces, Pula, 1998, ISSN 1330-1012. Tato práce pojednává o LSP ve zmíněném kontextu.

Specifické odkazy

externí odkazy