Partager via


Commentaires en C

Un « commentaire » est une séquence de caractères commençant par la combinaison d'une barre oblique et d'un astérisque (/*). Il est traité comme un espace blanc et il est ignoré par le compilateur. Un commentaire peut inclure toute combinaison de caractères du jeu de caractères utilisable, y compris les caractères de saut de ligne, à l'exclusion du séparateur « de fin de commentaire » (*/). Les commentaires peuvent occuper plusieurs lignes mais ne peuvent pas être imbriqués.

Ils peuvent être placés partout où un espace blanc est autorisé. Comme le compilateur traite un commentaire en tant qu'espace blanc unique, vous ne pouvez pas inclure de commentaires dans des jetons. Le compilateur ignore les caractères figurant dans un commentaire.

Utilisez les commentaires pour documenter votre code. L'exemple suivant est un commentaire accepté par le compilateur :

/* Comments can contain keywords such as
   for and while without generating errors. */

Des commentaires peuvent figurer sur la même ligne qu'une instruction de code :

printf( "Hello\n" );  /* Comments can go here */

Vous pouvez décider de placer un bloc de commentaires descriptifs avant des fonctions ou des modules de programme :

/* MATHERR.C illustrates writing an error routine 
 * for math functions. 
 */ 

Comme les commentaires ne peuvent pas contenir de commentaires imbriqués, l'exemple suivant génère une erreur :

/* Comment out this routine for testing 

   /* Open file */
    fh = _open( "myfile.c", _O_RDONLY );
    .
    .
    .
 */

L'erreur survient parce que le compilateur identifie la première combinaison */, après les mots Open file, comme la fin du commentaire. Il essaie de traiter la suite du texte et génère une erreur lorsqu'il trouve la combinaison */ en dehors d'un commentaire.

Bien que vous puissiez utiliser des commentaires pour rendre inactives certaines lignes de code à des fins de test, les directives de préprocesseur #if et #endif, ainsi que la compilation conditionnelle, représentent une alternative utile pour cette tâche. Pour plus d'informations, consultez Directives de préprocesseur dans Référence du préprocesseur.

Section spécifique à Microsoft

Le compilateur Microsoft prend également en charge les commentaires d'une ligne précédés de deux barres obliques (//). Lors d'une compilation avec /Za (norme ANSI), ces commentaires génèrent des erreurs. De tels commentaires ne peuvent pas être étendus à une deuxième ligne.

// This is a valid comment

Les commentaires commençant par deux barres obliques (//) se terminent par le caractère de saut de ligne suivant qui n'est pas précédé d'un caractère d'échappement. Dans l'exemple suivant, le caractère de saut de ligne est précédé d'une barre oblique inverse (\), créant ainsi une « séquence d'échappement ». Cette séquence d'échappement indique au compilateur de traiter la ligne suivante dans le cadre de la ligne précédente. (Pour plus d'informations, consultez Séquences d'échappement.)

// my comment \
    i++; 

Par conséquent, l'instruction i++; est mise en commentaires.

Par défaut pour Microsoft C, les extensions Microsoft sont activées. Utilisez /Za pour désactiver ces extensions.

FIN de la section spécifique à Microsoft

Voir aussi

Référence

Jetons C