Paradigme (programmation)
Un paradigme de programmation est une façon d'approcher la programmation informatique et de traiter les solutions aux problèmes et leur formulation dans un langage de programmation approprié. Il s'oppose à la méthodologie, qui est une manière d'organiser la solution des problèmes spécifiques du génie logiciel.
Utilisation
Un paradigme de programmation fournit (et détermine) la vue qu’a le développeur de l’exécution de son programme. Par exemple, en programmation orientée objet, les développeurs peuvent considérer le programme comme une collection d’objets en interaction, tandis qu’en programmation fonctionnelle un programme peut être vu comme une suite d'évaluations de fonctions sans états. Lors de la programmation d’ordinateurs ou de systèmes multi-processeurs, la programmation orientée processus permet aux développeurs de voir les applications comme des ensembles de processus agissant sur des structures de données localement partagées.
De la même manière que des courants différents du génie logiciel préconisent des méthodes différentes, des langages de programmation différents plaident pour des « paradigmes de programmation » différents. Certains langages sont conçus pour supporter un paradigme (en particulier Smalltalk et Java, qui supportent la programmation orientée objet, tandis que Haskell supporte la programmation fonctionnelle), alors que d’autres supportent des paradigmes multiples (à l’image de C++, Common Lisp, OCaml, Oz, Python, Ruby, Scala ou Scheme).
De nombreux paradigmes de programmation sont aussi célèbres pour les techniques qu’ils prohibent que pour celles qu’ils permettent. La programmation fonctionnelle pure, par exemple, interdit l’usage d’effets de bord ; la programmation structurée interdit l’usage du goto. En partie pour cette raison, les nouveaux paradigmes sont souvent considérés comme doctrinaires ou abusivement rigides par les développeurs habitués aux styles déjà existants. Cependant, le fait d’éviter certaines techniques peut permettre de rendre plus aisée la démonstration de théorèmes sur la correction d’un programme — ou simplement la compréhension de son fonctionnement — sans limiter la généralité du langage de programmation. De plus, il est possible d'écrire un programme en adoptant la programmation orientée objet même si le langage, par exemple le langage C, ne supporte pas ce paradigme.
La relation entre les paradigmes de programmation et les langages de programmation peut être complexe, car un langage de programmation peut supporter des paradigmes multiples. Pour citer un exemple, C++ est conçu pour supporter des éléments de programmation procédurale, de programmation orientée objet et de programmation générique. Cependant, concepteurs et développeurs décident de la méthode d’élaboration d’un programme en utilisant ces éléments de paradigmes. Il est possible d’écrire un programme purement procédural en C++, comme il est possible d’en écrire un purement orienté objet, ou encore qui relève des deux paradigmes.
Liste de paradigmes
Les paradigmes de la liste sont regroupés par grandes familles.
Types de programmation impérative (et dérivés)
- Programmation impérative, le paradigme originel et le plus courant
- Programmation structurée, visant à structurer les programmes impératifs pour en supprimer les instructions goto
- Programmation procédurale, à comparer à la programmation fonctionnelle
Types de programmation orientée objet (et dérivés)
- Programmation orientée objet, consistant en la définition et l’assemblage de briques logicielles appelées objets (comme en Smalltalk)
- Programmation orientée prototype, qui simplifie et rend plus flexible la programmation orientée objet
- Programmation orientée classe, à comparer à la Programmation orientée prototype (dans le contexte de la programmation orientée objet)
- Programmation orientée composant (comme en OLE)
Types de programmation déclarative (et dérivés)
- Programmation déclarative, consistant à déclarer les données du problème, puis à demander au programme de le résoudre
- Programmation descriptive, à l'expressivité réduite, qui permet de décrire des structures de données (par exemple, HTML ou LaTeX)
- Programmation fonctionnelle, avec laquelle un programme est une fonction au sens mathématique du terme
- Programmation logique, consistant à exprimer les problèmes et les algorithmes sous forme de prédicats (comme en Prolog)
- Programmation par contraintes, à comparer à la programmation logique
Autres types
- Programmation événementielle, consistant à répondre à des événements
- Programmation séquentielle
- Programmation interruptible, à comparer à la programmation événementielle
- Programmation concurrente, où l’on tient compte de l’exécution en parallèle de plusieurs piles sémantiques
- Programmation orientée aspect (comme en AspectJ)
- Programmation par contrat, dans lequel le déroulement des traitements est régi par des règles (comme en Eiffel)
- Programmation chimique, où les programmes sont vus comme des solutions chimiques abstraites. Les données sont des molécules dont les réactions chimiques représentent les opérations.
- Programmation orientée agent, souvent basée sur la programmation orientée objet, qui simplifie le développement d’agents logiciels
- Programmation orientée concept
- Programmation orientée pile (comme en Forth)
- Programmation orientée principes
- Programmation orientée flux de données, souvent utilisée pour les solutions de communication client/serveur, elle permet d'abstraire les différentes plateformes en se concentrant sur l'échange et le traitement des données. Elle est généralement représentée sous forme de diagrammes ou de graphes (voir Diagramme de flux de données) (comme dans un Tableur)
- Programmation non-déterministe
- Programmation orientée sujet
- Programmation réactive
- Programmation synchrone
- Programmation par annotations (comme en langage Flare)
- Programmation par attributs (comme avec les annotations Java, pré-traitées par la classe XDoclet, ou avec les attributs C#)
- Programmation sur flux, à comparer à la Programmation sur événement
- Programmation par messages, à comparer à la programmation impérative
- Programmation orientée processus, pour la programmation parallèle
- Programmation récursive, à comparer à la programmation itérative
- Programmation réflexive
- Programmation scalaire, à comparer à la programmation par tableaux
- Programmation au niveau valeur, à comparer à la programmation au niveau fonction
Voir aussi
Notes et références
- (en) Cet article est partiellement ou en totalité issu de l’article de Wikipédia en anglais intitulé « Programming paradigm » (voir la liste des auteurs).