Deklarativní programování - Declarative programming
Tento článek má několik problémů. Prosím pomozte vylepši to nebo diskutovat o těchto problémech na internetu diskusní stránka. (Zjistěte, jak a kdy tyto zprávy ze šablony odebrat) (Zjistěte, jak a kdy odstranit tuto zprávu šablony)
|
v počítačová věda, deklarativní programování je paradigma programování „Styl budování struktury a prvků počítačových programů“, který vyjadřuje logiku a výpočet bez popisu regulační tok.[1]
Mnoho jazyků, které tento styl používají, se pokouší minimalizovat nebo eliminovat vedlejší efekty popisem co program musí dosáhnout z hlediska problémová doména, spíše než popisovat jak dosáhnout toho jako posloupnost programování jazykové primitivy[2] (dále jen jak ponecháno na jazyk implementace ). To je v rozporu s imperativní programování, který implementuje algoritmy v explicitních krocích.[3]
Deklarativní programování často zvažuje programy jako teorie a formální logika a výpočty jako odpočty v tomto logickém prostoru. Deklarativní programování může značně zjednodušit psaní paralelní programy.[4]
Mezi běžné deklarativní jazyky patří jazyky jazyky dotazů na databázi (např., SQL, XQuery ), regulární výrazy, logické programování, Funkcionální programování, a správa konfigurace systémy.
Definice
Deklarativní programování je často definováno jako jakýkoli styl programování, který není rozkazovací způsob. Řada dalších běžných definic se pokouší definovat jej jednoduše porovnáním s imperativním programováním. Například:
- Program na vysoké úrovni, který popisuje, co by měl výpočet provádět.
- Libovolný programovací jazyk, který chybí vedlejší efekty (nebo konkrétněji je referenční transparentní )
- Jazyk s jasnou korespondencí matematická logika.[5]
Tyto definice se podstatně překrývají.
Deklarativní programování je nedůležitý styl programování, při kterém programy popisují požadované výsledky, aniž by výslovně uváděly příkazy nebo kroky, které je třeba provést. Funkční a logické programování jazyky se vyznačují deklarativním stylem programování. v logické programovací jazyky „Programy se skládají z logických příkazů a program se provádí hledáním důkazů o příkazech.
V čistý funkční jazyk, jako Haskell, všechny funkce jsou bez vedlejších účinků, a změny stavu jsou reprezentovány pouze jako funkce, které transformují stav, který je explicitně reprezentován jako a první třída objekt v programu. Ačkoli čisté funkční jazyky nejsou imperativní, často poskytují prostředky pro popis účinku funkce jako řadu kroků. Jiné funkční jazyky, jako např Lisp, OCaml a Erlang, podporovat směs procedurálního a funkčního programování.
Některé logické programovací jazyky, například Prolog a databázové dotazovací jazyky, jako je SQL, jsou sice v zásadě deklarativní, ale také podporují procedurální styl programování.
Podparadigmy
Deklarativní programování je deštníkové období která zahrnuje řadu známějších paradigmata programování.
Omezení programování
Omezení programování uvádí vztahy mezi proměnnými ve formě omezení, která určují vlastnosti cílového řešení. Sada omezení je vyřešen přidělením hodnoty každé proměnné tak, aby řešení bylo v souladu s maximálním počtem omezení. Omezovací programování často doplňuje další paradigmata: funkční, logické nebo dokonce imperativní programování.
Jazyky specifické pro doménu
Známé příklady deklarativních jazyky specifické pro doménu (DSL) zahrnují yacc vstupní jazyk generátoru analyzátoru, QML, Udělat sestavit specifikační jazyk, Loutka jazyk správy konfigurace, regulární výrazy a podmnožina SQL (SELECT dotazy, například). Výhodou DSL je, že jsou užitečné, i když to nutně nemusí být Turing-kompletní, což usnadňuje čistě deklarativnímu jazyku.
Mnoho značkovacích jazyků, jako je HTML, MXML, XAML, XSLT nebo jiný značkovací jazyky uživatelského rozhraní jsou často deklarativní. Například HTML pouze popisuje, co by se mělo na webové stránce objevit - neurčuje ani jednu regulační tok pro vykreslení stránky, ani stránka není možná interakce s uživatelem.
Od roku 2013[Aktualizace] některé softwarové systémy[který? ] kombinovat tradiční značkovací jazyky uživatelského rozhraní (například HTML) s deklarativním značením, které definuje, co (ale ne jak) by měly systémy back-end serveru podporovat deklarované rozhraní. Takové systémy, obvykle využívající specifickou doménu Obor názvů XML, může zahrnovat abstrakce syntaxe databáze SQL nebo parametrizovaná volání webových služeb pomocí přenos reprezentativního stavu (REST) a MÝDLO.[Citace je zapotřebí ]
Funkcionální programování
Funkční programovací jazyky jako Haskell, Systém, a ML vyhodnotit výrazy pomocí aplikace funkcí. Na rozdíl od souvisejícího, ale naléhavějšího paradigmatu Procedurální programování, funkční programování klade malý důraz na explicitní řazení (například v Systém, pořadí vyhodnocení mnoha druhů dílčích výrazů je nedefinované nebo implicitní[6]). Místo toho jsou výpočty charakterizovány různými typy rekurzivních funkce vyššího řádu aplikace a složení, s výslovnými odkazy na I / O a data zaměstnán střídmě, a státní mutace vyhnout se nebo zapouzdřeny, kdykoli je to možné.
Hybridní jazyky
Makefiles například specifikuje závislosti deklarativním způsobem,[7] ale zahrňte také nezbytný seznam akcí, které je třeba podniknout. Podobně yacc deklarativně určuje bezkontextovou gramatiku, ale obsahuje fragmenty kódu z hostitelského jazyka, který je obvykle imperativní (například C ).
Logické programování
Logické programovací jazyky jako Prolog stavové a dotazové vztahy. Specifika jak tyto dotazy jsou zodpovězeny, je na implementaci a jejím ověřovači vět, ale obvykle mají podobu jakési unifikace. Stejně jako funkční programování, mnoho logických programovacích jazyků umožňuje vedlejší účinky a ve výsledku nejsou striktně deklarativní.
Modelování
Modely nebo matematické reprezentace fyzických systémů mohou být implementovány do počítačového kódu, který je deklarativní. Kód obsahuje řadu rovnic, nikoli imperativních přiřazení, která popisují („deklarují“) vztahy chování. Když je model vyjádřen v tomto formalismu, je počítač schopen provádět algebraické manipulace, aby nejlépe formuloval algoritmus řešení. Matematická kauzalita je obvykle uložena na hranicích fyzického systému, zatímco popis chování samotného systému je deklarativní nebo kauzální. Deklarativní modelovací jazyky a prostředí Analytica, Modelica a Přirovnání.[8]
Viz také
Reference
- ^ Lloyd, J.W., Praktické výhody deklarativního programování
- ^ "deklarativní jazyk". FOLDOC. 17. května 2004. Citováno 26. ledna 2020.
- ^ Sebesta, Robert (2016). Koncepty programovacích jazyků. Boston: Pearson. ISBN 978-0-13-394302-3. OCLC 896687896.
- ^ „DAMP 2009: Workshop on Declarative Aspects of Multicore Programming“. Cse.unsw.edu.au. 20. ledna 2009. Citováno 15. srpna 2013.
- ^ Chakravarty, Manuel M. T. (14. února 1997). O masivně paralelním provádění deklarativních programů (Disertační práce). Technická univerzita v Berlíně. Citováno 26. února 2015.
V tomto kontextu je kritériem pro volání deklarativního programovacího jazyka existence jasné, matematicky ustavené korespondence mezi jazykem a matematickou logikou, takže deklarativní sémantika jazyka může být založena na modelu nebo teorii důkazu (nebo obojí) logiky.
- ^ „Revidováno7 Zpráva o schématu algoritmického jazyka " (PDF). Pracovní skupina pro režim 1. Citováno 2020-12-05.
- ^ [1] Archivováno 23. Října 2007 v Wayback Machine
- ^ „Deklarativní modelování“. Simulistika. Citováno 15. srpna 2013.
externí odkazy
- Frans Coenen. Charakteristika deklarativních programovacích jazyků. 1999.
- Robert Harper.
- Olof Torgersson. Poznámka k paradigmatům deklarativního programování a budoucnosti definičního programování. 1996.