Maison > développement back-end > Golang > Comment Go gère-t-il la division entière et comment puis-je garantir des résultats en virgule flottante ?

Comment Go gère-t-il la division entière et comment puis-je garantir des résultats en virgule flottante ?

Mary-Kate Olsen
Libérer: 2024-12-02 08:34:14
original
1008 Les gens l'ont consulté

How Does Go Handle Integer Division, and How Can I Ensure Floating-Point Results?

Comprendre la division dans Go

Contrairement à d'autres langages de programmation qui effectuent automatiquement une division en virgule flottante, Go nécessite une conversion explicite en virgule flottante pour la division opérations. Cela peut conduire à des résultats inattendus lorsque vous travaillez avec des entiers.

Considérez le code suivant :

fmt.Println(3 / 10)
Copier après la connexion

Cela affichera 0 au lieu du 0,3 attendu. La raison en est que les opérandes 3 et 10 sont tous deux des constantes entières non typées. Selon la spécification du langage Go, si les opérandes d'une opération binaire sont différents types de constantes non typées, l'opération et le résultat utilisent le type qui apparaît plus tard dans la liste : entier, rune, virgule flottante, complexe. Dans ce cas, l'entier apparaît avant la virgule flottante, le résultat est donc un entier non typé (0).

Pour obtenir un résultat en virgule flottante, l'un des opérandes doit être une constante à virgule flottante. Considérez ce qui suit :

fmt.Println(3.0 / 10.0)
fmt.Println(3.0 / 10)
fmt.Println(3 / 10.0)
Copier après la connexion

Toutes ces expressions seront évaluées à la constante à virgule flottante non typée 0,3. En ajoutant un .0 à l'un ou l'autre opérande, nous le convertissons explicitement en virgule flottante, ce qui donne un résultat en virgule flottante.

Lorsque l'opération de division implique un opérande typé, le type de l'opérande typé détermine le type de l'expression. Pour garantir un résultat float64, l'opérande tapé doit être float64. Par exemple :

var i3 = 3
var i10 = 10
fmt.Println(float64(i3) / 10)
fmt.Println(3 / float64(i10))
Copier après la connexion

Ces expressions convertiront les variables int en float64, ce qui donnera un résultat float64 de 0,3.

Il est important de noter que les littéraux numériques comme 10.0 et 3.0 ne sont pas typés flottants -des constantes point, pas float64. Des expressions comme i3/10.0 et 3.0/i10 donneront toujours un entier 0 car l'opérande tapé (i3 et i10) détermine le type du résultat.

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!

source:php.cn
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
Derniers articles par auteur
Tutoriels populaires
Plus>
Derniers téléchargements
Plus>
effets Web
Code source du site Web
Matériel du site Web
Modèle frontal