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
Mary-Kate Olsenoriginal
2024-12-02 08:34:14942parcourir

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)

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)

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))

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!

Déclaration:
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