Table des matières
Contenu de la question
Solution de contournement
Maison développement back-end Golang Différence dans les résultats des calculs de décalage au niveau du bit

Différence dans les résultats des calculs de décalage au niveau du bit

Feb 08, 2024 pm 09:11 PM
conversion implicite

Différence dans les résultats des calculs de décalage au niveau du bit

L'éditeur PHP Zimo vous propose un article sur "La différence dans les résultats du calcul du décalage au niveau du bit". En programmation informatique, l'opération de décalage de bits est une opération courante, qui peut effectuer des opérations de décalage vers la gauche ou la droite sur des nombres binaires. Cependant, différents langages de programmation peuvent présenter des différences dans le traitement des résultats des opérations de déplacement, ce qui oblige les développeurs à y prêter attention. Cet article présentera en détail les différences dans les résultats des opérations de déplacement dans différents langages de programmation et fournira quelques exemples pour aider les lecteurs à mieux comprendre et appliquer les opérations de déplacement. Que vous soyez un débutant ou un développeur possédant une certaine base en programmation, vous pouvez acquérir des connaissances et des compétences utiles grâce à cet article.

Contenu de la question

Il existe des différences dans la sortie de mon programme go, en particulier les variables x1 et x2. Voici l'extrait de code correspondant :

package main

var n uint = 10
const N uint = 10

func main() {
    var x1 byte = (1 << n) / 100
    var x2 byte = (1 << N) / 100
    println(x1, x2)
}
Copier après la connexion

Résultat attendu : 10 10

Sortie réelle : 0 10

Soyez curieux des raisons qui se cachent derrière les différences et cherchez des explications.

Solution de contournement

Les expressions constantes sont évaluées avec une précision non spécifiée. Attribué à x2 的所有内容都是恒定的,因此它可以正确计算 210 / 100 = 1024 / 100 = 10。而在第一个表达式中,1 被视为 byte,这意味着它会立即移出。 1 必须被视为 byte dans cahier des charges  :

Si l'opérande gauche d'une expression de décalage non const est une constante non typée, elle est d'abord implicitement convertie dans le type supposé lorsque l'expression de décalage est remplacée uniquement par son opérande de gauche.

1 est la constante non typée à gauche, nvar 使得表达式变得非常量,因此 1 必须具有其受让人 x1 的类型,即 byte.

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!

Déclaration de ce site Web
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn

Outils d'IA chauds

Undresser.AI Undress

Undresser.AI Undress

Application basée sur l'IA pour créer des photos de nu réalistes

AI Clothes Remover

AI Clothes Remover

Outil d'IA en ligne pour supprimer les vêtements des photos.

Undress AI Tool

Undress AI Tool

Images de déshabillage gratuites

Clothoff.io

Clothoff.io

Dissolvant de vêtements AI

AI Hentai Generator

AI Hentai Generator

Générez AI Hentai gratuitement.

Article chaud

R.E.P.O. Crystals d'énergie expliqués et ce qu'ils font (cristal jaune)
3 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Meilleurs paramètres graphiques
3 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Comment réparer l'audio si vous n'entendez personne
3 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌
Où trouver la courte de la grue à atomide atomique
1 Il y a quelques semaines By DDD

Outils chauds

Bloc-notes++7.3.1

Bloc-notes++7.3.1

Éditeur de code facile à utiliser et gratuit

SublimeText3 version chinoise

SublimeText3 version chinoise

Version chinoise, très simple à utiliser

Envoyer Studio 13.0.1

Envoyer Studio 13.0.1

Puissant environnement de développement intégré PHP

Dreamweaver CS6

Dreamweaver CS6

Outils de développement Web visuel

SublimeText3 version Mac

SublimeText3 version Mac

Logiciel d'édition de code au niveau de Dieu (SublimeText3)

Comment utiliser short en Java Comment utiliser short en Java May 07, 2024 am 03:33 AM

short est un type de données primitif en Java qui représente un entier signé de 16 bits compris entre -32 768 et 32 767. Il est souvent utilisé pour représenter de petits entiers, tels que des compteurs ou des identifiants, et prend en charge les opérations arithmétiques de base et les conversions de types. Mais comme short est un type signé, vous devez être prudent lorsque vous utilisez la division pour éviter tout débordement ou sous-dépassement.

Utilisation de ifnull dans SQL Utilisation de ifnull dans SQL Apr 28, 2024 am 09:57 AM

La fonction IFNULL vérifie si une expression est NULL et renvoie la valeur par défaut spécifiée si c'est le cas, sinon elle renvoie la valeur de l'expression. Il empêche les valeurs nulles de provoquer des erreurs, permet la manipulation des valeurs nulles et améliore la lisibilité des requêtes. L'utilisation comprend : le remplacement des valeurs nulles par des valeurs par défaut, l'exclusion des valeurs nulles des calculs et l'utilisation imbriquée pour gérer plusieurs situations de valeurs nulles.

Comment calculer la division en langage C Comment calculer la division en langage C Apr 13, 2024 pm 09:12 PM

En langage C, le comportement de l'opérateur de division / dépend du type de données des opérandes : Division entière : Lorsque l'opérande est un entier, une division entière est effectuée et le résultat est arrondi à l'inférieur. Division en virgule flottante : lorsque l'opérande est un nombre à virgule flottante, une division en virgule flottante est effectuée et le résultat est un nombre à virgule flottante. Conversion de type : lorsqu'un opérande est un entier et que l'autre ne l'est pas, l'entier est implicitement converti en nombre à virgule flottante, puis une division en virgule flottante est effectuée. Diviseur par 0 : Une erreur mathématique se produit lorsque le diviseur est 0. Fonctionnement modulo : utilisez l'opérateur % pour le fonctionnement modulo au lieu de la division modulo.

Que signifie char en Java ? Que signifie char en Java ? May 01, 2024 pm 06:15 PM

Le type char en Java est utilisé pour stocker un seul caractère Unicode, représentant 2 octets, allant de U+0000 à U+FFFF. Il est principalement utilisé pour stocker des caractères de texte. Il peut être initialisé via des guillemets simples ou des séquences d'échappement Unicode. et peuvent participer à la comparaison, les opérations d'égalité, d'inégalité et de jointure peuvent être implicitement converties en type int ou explicitement converties en objets Character.

Quelles sont les règles de correspondance pour la surcharge des fonctions C++ ? Quelles sont les règles de correspondance pour la surcharge des fonctions C++ ? Apr 27, 2024 am 08:27 AM

Les règles de correspondance de surcharge de fonctions C++ sont les suivantes : faire correspondre le nombre et le type de paramètres dans l'appel. L'ordre des paramètres doit être cohérent. Les modificateurs de constance et de référence doivent correspondre. Les paramètres par défaut peuvent être utilisés.

Que signifie * dans MySQL Que signifie * dans MySQL Apr 26, 2024 am 07:21 AM

L'astérisque (*) dans MySQL signifie « tout » et a différentes utilisations : Sélectionner toutes les colonnes Sélectionner toutes les lignes Caractères génériques JOIN pour la clause LIKE de table Quantificateur Conversion de type implicite pour la clause REGEXP

Quels sont les types de paramètres de fonction PHP ? Quels sont les types de paramètres de fonction PHP ? Apr 10, 2024 pm 04:21 PM

Les types de paramètres de fonction PHP incluent les types scalaires (entiers, nombres à virgule flottante, chaînes, valeurs booléennes, valeurs nulles), les types composites (tableaux, objets) et les types spéciaux (fonctions de rappel, paramètres variables). Les fonctions peuvent convertir automatiquement des paramètres de différents types, mais elles peuvent également forcer des types spécifiques via des déclarations de type pour éviter les conversions accidentelles et garantir l'exactitude des paramètres.

Utilisation de (+ dans Oracle Utilisation de (+ dans Oracle May 08, 2024 pm 08:12 PM

L'opérateur plus (+) dans Oracle peut être utilisé pour : connecter des chaînes, des nombres, des dates et des intervalles de temps ; gérer les valeurs NULL et convertir les valeurs NULL en valeurs non NULL ; convertir les types de données en types de chaîne.

See all articles