La programmation déclarative est un paradigme de programmation qui consiste à créer des applications sur la base de composants logiciels indépendants du contexte et ne comportant aucun état interne. Autrement dit, l’appel d’un de ces composants avec les mêmes arguments produit exactement le même résultat, quel que soit le moment et le contexte de l’appel.

En programmation déclarative, on décrit le quoi, c’est-à-dire le problème. Par exemple, le langage Prolog est déclaratif car il décrit un problème et des comportements (sous forme de règles, de prédicats, etc.) et résout ensuite le problème avec un solveur mathématique qui va essayer toutes les possibilités tout en restant au sein des contraintes.

Alors qu’en programmation impérative (par exemple avec le C ou Java), on décrit le comment, c’est-à-dire la structure de contrôle correspondant à la solution.

C’est une forme de programmation sans effets de bord, ayant généralement une correspondance avec la logique mathématique.

Il existe plusieurs formes de programmation déclarative :

  • la programmation descriptive, à l’expressivité réduite, qui permet de décrire des structures de données, comme HTML ou LaTeX. Il est à noter que, là où ces langages sont déclaratifs, l’appelation de « programmation » prête à débats car on ne résout pas de problème avec eux.

Bibliographie

modifier
  • Peter Van Roy, Seif Haridi. Concepts, Techniques, and Models of Computer Programming. MIT Press, 2004.

Sur les autres projets Wikimedia :

Liens externes

modifier

📚 Artikel Terkait di Wikipedia

Ada (langage)

Ada Programming Language (en) Site d'information sur Ada 2012 John Barnes (en) (trad. Hugues Fauconnier), Programmer en ADA 95 [« Programming in Ada

Machine de Krivine

International ACM SIGPLAN Conference on Principles and Practice of Declarative Programming (PPDP'03), (en) Pierre-Louis Curien, « An Abstract Framework for

Langage de programmation

programmation (anglais : programming languages), ou langages de haut niveau, sont tous les langages généralistes (en) Seema Kedar, Programming Paradigms And Methodology

Mercury (langage)

algorithm of Mercury: an efficient purely declarative logic programming language », Journal of Logic Programming, vol. 29, nos 1–3,‎ october–december 1996

Open Programming Language

sources ? L’OPL (pour Open Programming Language, précédemment Optimization Programming Language ou Organiser Programming Language) est le langage de

Programmation informatique

s'y prêtent très mal. Article détaillé : Programmation déclarative. En programmation déclarative, le programme est indépendant de l’état de la machine

Racket (langage)

Combining Lazy and Strict Languages for Teaching". Functional and Declarative Programming in Education. Flatt, M.; Barzilay, E.; Findler, R. B. (2009). "Scribble:

Programmation fonctionnelle

faut ajouter XSLT et Anubis. (en) « Functional Programming » « Functional vs. Procedural Programming Language », sur web.archive.org, 13 novembre 2007