<!-- Raz le brol -->

Le 07/03/2011 : @Override et l'interface en Java

[râlerie]
D'ju il manque l'annotation @implement en Java
[/râlerie]

En effet, si je déclare une méthode dans une interface, une erreur de compilation est générée si cette méthode n'est pas implémentée dans la classe qui implémente cette interface (je ne respecte pas le contrat défini par l'interface).

Et où est le problème ?

Mais si par la suite nous supprimons une méthode de notre interface ?

Le compilateur ne sait pas que la méthode implémentée dans la classe correspondait à un ancien contrat avec l'interface, et n'est plus d'aucune utilité (nous ne nous attardons pas ici au choix de la suppression d'une méthode publique et aux conséquences sur le refactoring).

Et @Override ?

Lorsque nous redéfinissons (“override” (en français, « surcharge »)) dans une classe une méthode définie dans une super-classe, nous devrions toujours l'annoter avec @Override. De cette manière, la maintenance du code est facilitée, car nous avons des erreurs de compilation si cette méthode n'existe plus en amont dans la hiérarchie de cette classe, si le nom est modifié, etc.

Pourquoi Steph râle sur @Override ?

Dans le cas d'une classe qui fournit l'implémentation d'une méthode définie dans une classe parent abstraite, il n'est pas logique de marquer cette méthode avec l'annotation @Override, car il n'y a pas encore eu d'implémentation. Pourtant c'est ce que je fais; dans ce cas, j'utilise l'annotation @Override, car il n'existe pas d'alternative permettant de forcer l'erreur de compilation en cas de mauvaise maintenance.

Une annotation @implement serait la bienvenue dans ce cas, et serait plus appropriée au niveau sémantique.

Si nous considérons une interface comme une classe abstraite dont toutes les méthodes sont publiques et abstraites, la première implémentation d'une méthode définie dans l'interface serait annotée @implement, et si elle est surchargée par la suite, la surcharge serait annotée @Override.

« Raz-le-Brol... »

English translation

You have asked to visit this site in English. For now, only the interface is translated, but not all the content yet.

If you want to help me in translations, your contribution is welcome. All you need to do is register on the site, and send me a message asking me to add you to the group of translators, which will give you the opportunity to translate the pages you want. A link at the bottom of each translated page indicates that you are the translator, and has a link to your profile.

Thank you in advance.

Document created the 11/06/2010, last modified the 04/10/2024
Source of the printed document:https://www.gaudry.be/en/raz-le-brol-rf-override-interface.html

The infobrol is a personal site whose content is my sole responsibility. The text is available under CreativeCommons license (BY-NC-SA). More info on the terms of use and the author.

Notes
  1.  override : corresponds to « surcharge » en français

Contents Haut