Pour commencer, vous savez probablement que const
peut être utilisé pour rendre les données d'un objet ou un pointeur non modifiable ou les deux.
const Object* obj; // can't change data
Object* const obj; // can't change pointer
const Object* const obj; // can't change data or pointer
Cependant, vous pouvez également utiliser la syntaxe :
Object const *obj; // same as const Object* obj;
La seule chose qui semble avoir de l'importance est le côté de l'astérisque où vous mettez le const
mot-clé. Personnellement, je préfère mettre const
à gauche du type pour spécifier que ses données ne sont pas modifiables, car je trouve que cela se lit mieux dans mon esprit de gauche à droite, mais quelle syntaxe est venue en premier ?
Plus important encore, pourquoi y a-t-il deux façons correctes de spécifier const
et dans quelle situation préféreriez-vous ou auriez-vous besoin de l'un plutôt que de l'autre, le cas échéant ?
Edit :
Il semble donc qu'il s'agisse d'une décision arbitraire alors que la norme sur la façon dont les compilateurs doivent interpréter les choses a été rédigée bien avant ma naissance. Depuis const
est appliqué à ce qui se trouve à gauche du mot-clé (par défaut ?) Je suppose qu'ils ont pensé qu'il n'y avait aucun mal à ajouter "raccourcis" pour appliquer les mots-clés et les qualificatifs de type d'une autre manière, au moins jusqu'à ce que la déclaration soit modifiée par l'analyse d'un * ou d'un & ...
C'était aussi le cas en C, je suppose ?
13 votes
Dans les macros, ajoutez toujours
const
après le type, par exemple#define MAKE_CONST(T) T const
au lieu de#define MAKE_CONST(T) const T
de sorte queMAKE_CONST(int *)
s'étendra correctement àint * const
au lieu deconst int *
.14 votes
J'ai vu ces deux styles désignés par les termes "const est" et "const ouest".
35 votes
@TomAnderson mais en réalité cela devrait être "east const" et "const west".