Maison >développement back-end >C++ >Quelle est la différence entre un comportement non défini et un comportement défini par l'implémentation dans les changements de bits en C et C ?
Comportement non défini ou défini par l'implémentation dans les décalages au niveau du bit
L'opérateur de décalage à gauche au niveau du bit (<<) soulève des questions concernant son comportement avec des opérandes négatifs de gauche. Cet article explore pourquoi cette opération produit un comportement non défini en C mais uniquement un comportement défini par l'implémentation en C.
Comportement non défini de C
Selon la norme ISO C99, le décalage vers la gauche d'un l'opérande négatif entraîne un comportement indéfini. En effet, la norme stipule que le résultat doit être le produit de l'opérande de gauche et 2E2, le résultat étant modulo la plage du type de résultat. Cependant, lorsque l'opérande de gauche est négatif, un tel calcul peut conduire à des résultats indéfinis dans des contextes de type signé.
Le comportement bien défini de C
Contrairement à C, C spécifie que le déplacement vers la gauche d'un opérande non signé donne la multiplication mathématique attendue. Cependant, pour les types signés, C définit également un comportement non défini si le résultat dépasse la plage représentable du type de résultat. Ainsi, en C , les opérandes négatifs décalés vers la gauche restent indéfinis.
Raisons de la divergence
La raison de l'approche différente de C découle probablement du fait que son le comportement négatif est déjà indéfini en raison du débordement potentiel. L'extension de la définition pour couvrir tous les cas négatifs a simplifié la norme et clarifié le comportement non défini.
Comportement de décalage à droite défini par l'implémentation
Le déplacement vers la droite d'un opérande négatif est une implémentation- défini à la fois en C et en C car il peut impliquer un choix entre l'extension du signe et le remplissage par zéro. L'extension de signe conserve le bit de signe d'origine dans les bits libérés, tandis que le remplissage par zéro les remplace par des zéros. Différents compilateurs et plates-formes peuvent choisir l'un ou l'autre comportement, d'où la nature définie par l'implémentation.
En résumé
En C, le décalage vers la gauche d'un opérande négatif entraîne inconditionnellement un comportement indéfini . En C , une telle opération n'est pas non plus définie pour les types signés. Le décalage vers la droite d'un opérande négatif, en revanche, est défini par l'implémentation dans les deux langues en raison du choix entre l'extension de signe et le remplissage par zéro.
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!