bloc2:prog:poo:classesabstraites
Différences
Ci-dessous, les différences entre deux révisions de la page.
| Les deux révisions précédentesRévision précédenteProchaine révision | Révision précédente | ||
| bloc2:prog:poo:classesabstraites [2023/04/02 21:44] – yvinec.t | bloc2:prog:poo:classesabstraites [2023/04/11 12:00] (Version actuelle) – [Concept] admin | ||
|---|---|---|---|
| Ligne 12: | Ligne 12: | ||
| Exemple : | Exemple : | ||
| - | <code=java>// une classe abstraite A | + | < |
| + | // une classe abstraite A | ||
| public abstract class A | public abstract class A | ||
| { | { | ||
| Ligne 23: | Ligne 24: | ||
| public abstract void autreMethode (int nombre) ; | public abstract void autreMethode (int nombre) ; | ||
| } | } | ||
| + | </ | ||
| + | <code java B.java> | ||
| + | // une classe qui dérive la classe abstraite A | ||
| + | public class B extends A | ||
| + | { | ||
| + | |||
| + | // implémentation de la méthode abstraite de A : obligatoire, | ||
| + | // sinon B reste abstraite | ||
| + | public void autreMethode (int param) { | ||
| + | ... | ||
| + | } | ||
| + | } | ||
| + | |||
| + | // instanciation d'une classe qui dérive une classe abstraite : OK | ||
| + | B b = new B (...) ; | ||
| </ | </ | ||
| ===== Bénéfices ===== | ===== Bénéfices ===== | ||
| * On peut placer dans une **classe abstraite** toutes les **fonctionnalités** dont on souhaite disposer dans ses **classes dérivées**, | * On peut placer dans une **classe abstraite** toutes les **fonctionnalités** dont on souhaite disposer dans ses **classes dérivées**, | ||
| - | |||
| * On peut utiliser des **classes abstraites** pour simplement empêcher qu’une classe ne soit **instanciée** parce que son existence en tant que classe est **uniquement technique** et ne repose pas sur le besoin de manipuler l’objet en tant que tel. | * On peut utiliser des **classes abstraites** pour simplement empêcher qu’une classe ne soit **instanciée** parce que son existence en tant que classe est **uniquement technique** et ne repose pas sur le besoin de manipuler l’objet en tant que tel. | ||
| + | ===== Règles de construction ===== | ||
| + | * Dès qu’une classe comporte une ou plusieurs méthodes abstraites, elle est abstraite, même si on ne l’indique pas avec le mot-clé « abstract » dans sa définition. | ||
| - | ===== Comment | + | * Une classe qui hérite d’une classe abstraite n’est pas tenue de redéfinir toutes |
| - | === Définir la classe abstraite en utilisant le mot-clé " | + | ===== Exemples d' |
| - | < | + | === Définir |
| - | + | ||
| - | </ | + | |
| - | + | ||
| - | === Définir | + | |
| < | < | ||
| + | public abstract class Classe_A { | ||
| + | ... | ||
| + | } | ||
| </ | </ | ||
| - | + | === Définir des méthodes abstraites | |
| - | === Hériter de la classe abstraite dans une classe concrète en utilisant le mot-clé " | + | |
| < | < | ||
| + | public | ||
| + | // Bien observer ici qu'il s'agit d'une signature de méthode : | ||
| + | // + Pas de corps défini => pas de {} | ||
| + | // + Un point-virgule en fin de ligne | ||
| + | public abstract void uneMethode (liste_de_paramètres); | ||
| + | ... | ||
| + | } | ||
| </ | </ | ||
| - | === Implémenter les méthodes abstraites dans la classe | + | === Hériter de la classe |
| < | < | ||
| + | public class Classe_B extends Classe_A { | ||
| + | ... | ||
| + | } | ||
| </ | </ | ||
| - | === Utiliser la classe concrète pour instancier des objets et appeler | + | === Implémenter |
| < | < | ||
| + | public class UneClasse extends Classe_A { | ||
| + | @Override | ||
| + | public void uneMethode (liste_de_paramètres) { | ||
| + | // Implémentation de la méthode ... qui n'est plus abstraite | ||
| + | } | ||
| + | } | ||
| </ | </ | ||
| + | |||
bloc2/prog/poo/classesabstraites.1680464646.txt.gz · Dernière modification : 2023/04/02 21:44 de yvinec.t
