=====Définitions===== ====Interface==== Une interface est un contrat qui définit un ensemble de méthodes. Les classes qui implémenteront cette interface devront au minimum implémenter ces méthodes. Les interfaces peuvent servirent dans plusieurs cas : * Forcer un groupe de classes à implémenter au minimum certaines méthodes. L'exemple classique est la classe ''Animal'' avec la méthode ''Aller''. Un cheval, il va utiliser 4 pattes, une poule deux, une araignée huit et un poisson va battre de la queue, * Permettre de développer une fonctionnalité utilisant l'interface en attendant qu'une autre personne développe la classe qui respectera l'interface, * Faciliter l'écriture des tests. Si une classe manipule un matériel physique, il peut être difficile de tester une autre classe exploitant le matériel. Il pourra être alors intéressant de remplacer la classe matériel par une fausse classe dite ''mock''. * "Les composants sont visibles des autres composants exclusivement à travers des interfaces". {{doc:poo:interface.png|Interface}} ====Abstraction==== Représenter la réalité comme étant un objet. En pratique cela consiste à définir des méthodes dans une classe. Les méthodes peuvent être déjà implémentées ou alors également laissées abstraites pour forcer le développeur à les implémenter ultérieurement. ====Encapsulation==== L'encapsulation regroupe toutes les données et les méthodes implémentées pour les exploiter. Les données peuvent être regroupées dans des ''POJO''/''POCO''/… et invisibles, si besoin, de l'extérieur. {{doc:poo:encaps.gif|Encapsulation}} [[http://hdd34.developpez.com/cours/artpoo/|Introduction à la Programmation Orientée Objet]] {{ :doc:poo:artpoo.pdf |Archive du 10/09/2011 le 26/04/2020}} * Partage de données
The tempting and straight forward approach for realizing undo is to store the state information directly in the command objects. In many cases this will expose parts of the internal structure of the model and violate the principle of encapsulation.[[https://dl.acm.org/citation.cfm?doid=1411732.1411738|A framework for command processing in Java/Swing programs based on the MVC pattern]] {{ :helloworld:design_pattern:command:undomanager:a_framework_for_command_processing_in_javaswing_pr.pdf |Archive}}====Héritage==== L'héritage permet de spécialiser une classe. Il reprend toutes les caractéristiques d'une classe en redéfinissant ou ajoutant des méthodes et en ajoutant des attributs. {{doc:poo:poo1.png|Héritage}} [[https://www.geek-directeur-technique.com/2012/01/10/les-langages-de-programmation-partie-2-le-modele-objet|classe – De geek à directeur technique]] {{ :doc:poo:les_langages_de_programmation_partie_2_le_modele_objet_de_geek_a_directeur_technique_2020-04-26_11_08_19_pm_.html |Archive du 10/01/2012 le 26/04/2020}} ====Polymorphisme / redéfinition==== Le polymorphisme est donc la capacité du système à choisir la méthode qui correspond au type réel de l'objet en cours. {{doc:poo:polym.gif|}}