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/04 11:44] – [Concept] admin | bloc2:prog:poo:classesabstraites [2023/04/11 12:00] (Version actuelle) – [Concept] admin | ||
|---|---|---|---|
| Ligne 12: | Ligne 12: | ||
| Exemple : | Exemple : | ||
| - | <code=java A.java> | + | <code java A.java> |
| // une classe abstraite A | // une classe abstraite A | ||
| public abstract class A | public abstract class A | ||
| Ligne 25: | Ligne 25: | ||
| } | } | ||
| </ | </ | ||
| - | <code=java B.java> | + | <code java B.java> |
| // une classe qui dérive la classe abstraite A | // une classe qui dérive la classe abstraite A | ||
| public class B extends A | public class B extends A | ||
| Ligne 43: | Ligne 43: | ||
| * 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 | + | ===== Exemples d' |
| + | |||
| + | === Définir | ||
| < | < | ||
| - | public abstract class MaClasseAbstraite | + | public abstract class Classe_A |
| - | | + | |
| } | } | ||
| </ | </ | ||
| - | + | === Définir des méthodes abstraites === | |
| - | === Définir | + | |
| < | < | ||
| - | public | + | public |
| - | | + | |
| - | + | // | |
| - | public abstract void methodeAbstraite(); | + | // + Un point-virgule en fin de ligne |
| + | public abstract void uneMethode | ||
| + | ... | ||
| } | } | ||
| - | |||
| </ | </ | ||
| - | === Hériter de la classe abstraite | + | === Hériter de la classe abstraite |
| < | < | ||
| - | public class MaClasseConcrete | + | public class Classe_B |
| - | | + | |
| } | } | ||
| - | |||
| </ | </ | ||
| - | === Implémenter les méthodes abstraites | + | === Implémenter les méthodes abstraites === |
| < | < | ||
| - | public class MaClasseConcrete | + | public class UneClasse |
| - | protected int variableAbstraite; | + | |
| - | public void methodeAbstraite() { | + | |
| - | // Implémentation de la méthode abstraite | + | |
| + | // Implémentation de la méthode | ||
| } | } | ||
| } | } | ||
| - | |||
| </ | </ | ||
| - | === Utiliser la classe concrète pour instancier des objets et appeler les méthodes héritées de la classe abstraite. === | ||
| - | < | ||
| - | MaClasseConcrete objet = new MaClasseConcrete(); | ||
| - | objet.methodeAbstraite(); | ||
| - | |||
| - | </ | ||
bloc2/prog/poo/classesabstraites.1680601493.txt.gz · Dernière modification : 2023/04/04 11:44 de admin
