Ordre d'évaluation des instructions d'affectation en C
Un résultat déroutant peut être obtenu lors de l'attribution d'une valeur à une carte :
<code class="cpp">map<int, int> mp; printf("%d ", mp.size()); mp[10] = mp.size(); printf("%d\n", mp[10]);</code>
Ce code s'imprime :
0 1
Ce résultat peut sembler contre-intuitif, car on pourrait s'attendre à ce que la taille de la carte soit de 1 après l'affectation. Cependant, l'ordre d'évaluation de l'instruction d'affectation joue ici un rôle crucial.
Le côté gauche de l'affectation mp[10] renvoie une référence à la valeur sous-jacente de l'élément de carte. Simultanément, cette action crée une nouvelle valeur pour l'élément mp[10]. Ce n'est qu'après cette opération que le côté droit est évalué, en utilisant la taille nouvellement calculée de la carte.
Ce comportement n'est pas explicitement indiqué dans la norme C mais relève d'un comportement non spécifié. Une proposition récente, N4228, vise à affiner l'ordre des règles d'évaluation pour spécifier de tels cas.
La section pertinente du projet de norme C 11 (1.9) stipule que les évaluations des sous-expressions d'expressions individuelles ne sont généralement pas séquencées. Cependant, les appels de fonction (tels que l'opérateur [] et la taille()) sont séquencés avant l'exécution du corps de la fonction appelée.
Par conséquent, l'opérande droit de l'expression d'affectation est séquencé après l'opérande gauche, ce qui donne le comportement observé. Cela signifie que l'ordre d'évaluation est le suivant :
Une mise à jour du standard C devrait spécifier ce comportement, indiquant clairement que l'opérande droit d'une expression d'affectation est séquencé avant l'opérande de gauche.
Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!