Commentaire (informatique)
Les commentaires sont, en programmation informatique, des portions du code source ignorées par le compilateur ou l’interpréteur, car destinées en général à un lecteur humain et non censées influencer l’exécution du programme.
Les commentaires sont le plus souvent utilisés pour expliquer le code ; certains outils, appelés générateurs de documentation, permettent d’extraire l’information disponible dans les commentaires pour créer automatiquement une documentation du programme.
On utilise parfois une mise en commentaires pour court-circuiter quelque temps une section de code, mais aussi pour préciser des contraintes ou des propriétés, notamment des préconditions, des postconditions et des invariants comme cela se fait dans la programmation par contrat.
Types de commentaires
Les façons de distinguer les commentaires du reste du code varient suivant le langage utilisé. On distingue trois catégories principales, chaque langage pouvant implémenter plusieurs catégories de commentaires :
- commentaires en pleine ligne ;
- commentaires de fin de ligne ;
- commentaires en bloc.
Commentaires en pleine ligne
Un commentaire en pleine ligne commence par un marqueur annonçant une ligne de commentaires (ou par l’absence d’un marqueur annonçant une ligne de code). BASIC, Fortran et Cobol sont des langages utilisant des commentaires en pleine ligne. Le code reprend naturellement à la ligne suivante.
- BASIC :
REM commentaire
- Cobol :
000010*COMMENTAIRE
- (l’astérisque doit se trouver en 7e position sur la ligne)
- Fortran :
C commentaire
- (exactement 6 espaces entre le caractère
C
et le commentaire ;C
doit absolument être le premier caractère de la ligne)
rem commentaire
// commentaire
' commentaire
rem commentaire
Commentaires de fin de ligne
Un commentaire de fin de ligne commence par un marqueur annonçant le début d’un commentaire, et se termine automatiquement à la fin de la ligne, sans nécessité de marqueur de fin. Les langages C++ et Java utilisent ce type de commentaires.
- Ada, AppleScript, Lua, Lingo, Haskell, Transact-SQL :
--commentaire
⍝(symbole "lampe". Attention, c'est de l'Unicode)
; commentaire
- BASIC :
REM commentaire
(après un « : » dans QBasic)' commentaire
// commentaire
- DCL :
$! commentaire
! commentaire
- mySQL :
--commentaire
#commentaire
# commentaire
- PHP :
# commentaire
// commentaire
- PILOT :
R:commentaire
- (une lettre de commande peut débuter immédiatement après le commentaire, sur la même ligne)
- TeX, LaTeX, PostScript, Matlab :
% commentaire
- Texinfo :
@c commentaire
@comment commentaire
' commentaire
' commentaire
// commentaire
- VHDL :
-- commentaire
Commentaires en bloc
Un commentaire en bloc commence par un marqueur annonçant le début d’un commentaire et se termine avec un marqueur annonçant sa fin, leur intérêt principal est de pouvoir mettre en commentaire plusieurs lignes sans éditer chacune d'entre elles. Les langages Pascal et C utilisent ce type de commentaires.
- Algol :
comment commentaire;
(* commentaire *)
/* commentaire */
- Forth :
(commentaire)
- D :
/* commentaire */
/+ commentaire +/
- Delphi :
(* commentaire *)
{ commentaire }
- Haskell :
{- commentaire -}
- Lua :
--[[ commentaire ]]
<!-- commentaire -->
- Python :
Python n'a pas de commentaire en bloc à proprement parler[1], mais les chaînes de caractères constituant à elles-seules une instruction peuvent jouer ce rôle, pour éventuellement servir de docstring[2]: """ commentaire """
ou ''' commentaire '''
- VHDL 2008 :
/* commentaire */
Commentaires de fin de fichier
Un commentaire de fin de fichier commence par un marqueur annonçant que tout ce qui suit, jusqu’à la fin du fichier, doit être considéré comme un commentaire. ATS est un exemple de langage utilisant ce type de commentaires.
- ATS :
//// commentaire
- Tcl :
- Grâce à un caractère de contrôle: ^Z [3]
Utilisation des commentaires
Documentation
Des outils comme Doxygen, Javadoc ou RDoc permettent de structurer les commentaires présents dans le code et de créer une documentation complète. Celle-ci est la plupart du temps destinée à un programmeur désirant développer avec une bibliothèque, mais il est tout à fait possible d’utiliser cette méthode pour écrire la documentation destinée à l’utilisateur final.
/**
* Registers the text to display in a tool tip. The text
* displays when the cursor lingers over the component.
*
* @param text the string to display. If the text is null,
* the tool tip is turned off for this component.
*/
public void setToolTipText(String text) {
(un extrait de la documentation javadoc de Sun Microsystems ; le commentaire est dans un format compréhensible par le processeur javadoc)
DĂ©sactivation de code
On utilise souvent les commentaires pour cacher rapidement des portions de code au compilateur ou à l’interpréteur, par exemple pour tester des implémentations alternatives, ou pour désactiver temporairement des fonctionnalités.
Cette désactivation est la plus facile à effectuer lorsque le langage permet des commentaires par blocs. Cependant, dans le cas où la portion de code à cacher contient déjà des commentaires, la syntaxe du langage ne permet pas toujours simplement d’imbriquer ces commentaires. Certains langages fournissent un niveau supérieur de commentaires pour pallier cela :
#if 0
code; //commentaire
encore du code; /* commentaire */
#endif
- XML :
<![IGNORE[
<code> <!-- commentaire --> </code>
]]>
Astuce du code facilement (dé)commentable
/*/*
Mon code
//*/
Pour le décommenter, il suffit de retirer la 1re étoile *.
Pour alterner entre deux blocs de code en C (C99), C++, C#, Java, JavaScript, PHP :
/* --- */ // 1er bloc actif
Code version 1
/*/
Code version 2
/* --- */
Pour activer le second bloc, il suffit d'ajouter un espace entre l'étoile et le slash de la première ligne :
/* --- * / // 2ème bloc actif
Code version 1
/*/
Code version 2
/* --- */
Cependant l'utilisation des commentaires de bloc pour commenter une partie du code n'est pas compatible avec du code contenant des blocs de commentaires car ils ne peuvent pas être imbriqués. L'utilisation des commentaires de fin de ligne, qui n'a pas ce problème, est la solution utilisée par la plupart des éditeurs de code source.
Exemples
C
(extrait du fichier fork.c
du noyau Linux)
/*
* Check if we are over our maximum process limit, but be sure to
* exclude root. This is needed to make it possible for login and
* friends to set the per-user process limit to something lower
* than the amount of processes root is running. -- Rik
*/
if (atomic_read(&p->user->processes) >= p->rlim[RLIMIT_NPROC].rlim_cur
&& !capable(CAP_SYS_ADMIN) && !capable(CAP_SYS_RESOURCE))
goto bad_fork_free;
Perl
(extrait de perlbug.PL
dans la distribution standard de Perl)
# a strange way to check whether any significant editing
# have been done: check whether any new non-empty lines
# have been added. Yes, the below code ignores *any* space
# in *any* line.
while (<REP>) {
s/\s+//g;
$unseen++ if $_ ne '' and not exists $REP{$_};
}
PHP
(extrait de MediaWiki, le logiciel utilisé par Wikipedia)
/*
* Scan forwards to find beginning of another run of changes.
* Also keep track of the corresponding point in the other file.
*
* Throughout this code, $i and $j are adjusted together so that
* the first $i elements of $changed and the first $j elements
* of $other_changed both contain the same number of zeros
* (unchanged lines).
* Furthermore, $j is always kept so that $j == $other_len or
* $other_changed[$j] == false.
*/
while ($j < $other_len && $other_changed[$j])
$j++;
Notes et références
- (en) PEP8.
- (en) PEP257.
- (en) http://wiki.tcl.tk/8369.