CONNEXION
  • RetourJeux
    • Sorties
    • Hit Parade
    • Les + populaires
    • Les + attendus
    • Soluces
    • Tous les Jeux
    • Gaming
  • RetourActu Gaming
    • News
    • Astuces
    • Tests
    • Previews
    • Toute l'actu gaming
  • RetourBons plans
    • Bons plans
    • Bons plans Smartphone
    • Bons plans Hardware
    • Bons plans Image et Son
    • Bons plans Amazon
    • Bons plans Cdiscount
    • Bons plans Decathlon
    • Bons plans Fnac
    • Tous les Bons plans
  • RetourJVTech
    • Actus High-Tech
    • Intelligence Artificielle
    • Smartphones
    • Mobilité urbaine
    • Hardware
    • Image et son
    • Tutoriels
    • Tests produits High-Tech
    • Guides d'achat High-Tech
    • JVTech
  • RetourCulture
    • Actus Culture
    • Culture
  • RetourVidéos
    • A la une
    • Gaming Live
    • Vidéos Tests
    • Vidéos Previews
    • Gameplay
    • Trailers
    • Chroniques
    • Replay Web TV
    • Toutes les vidéos
  • RetourForums
    • Hardware PC
    • PS5
    • Switch 2
    • Xbox Series
    • Switch
    • Pokemon pocket
    • FC 25 Ultimate Team
    • League of Legends
    • Tous les Forums
  • PC
  • PS5
  • Xbox Series
  • Switch 2
  • PS4
  • One
  • Switch
  • iOS
  • Android
  • MMO
  • RPG
  • FPS
En ce moment Genshin Impact Valhalla Breath of the wild Animal Crossing GTA 5 Red dead 2
Liste des sujets

Aidez moi a comprendre les double en java

iks789
iks789
Niveau 26
20 décembre 2021 à 21:54:34

J'ai un résultat très étrange lorsque j'utilise ma fonction et je pense qu'il me manque quelque chose avec l'arrondi et le double en java.

Par exemple quand je donne la valeur 00159,300 pour le nombre et 100 pour la conversion j'ai 15930,000000000002 ce qui n'est pas possible !

Le code ici :
public static String convertMultiply(String number,String conversion) { number=number.replace(",", "."); BigDecimal res=BigDecimal.valueOf(Double.valueOf(number)*Integer.valueOf(conversion)); res=res.stripTrailingZeros(); return res.toPlainString().replace(".", ","); } }

Message édité le 20 décembre 2021 à 21:55:40 par iks789
Pseudo supprimé
Pseudo supprimé 20 décembre 2021 à 22:18:04

https://fr.wikipedia.org/wiki/Virgule_flottante

godrik
godrik
Niveau 30
20 décembre 2021 à 23:55:14

Ça m'a l'air normale. Double représente les nombre avec un format a virgule flottante sur 64 bit. Le nombre que tu cherches à représenter n'est pas representable avec double. Donc il te donne la valeure la plus près. Si il te faut une représentation exacte alors regardes du côté des nombres a virgules fixe.

woutGRIMPEUR
woutGRIMPEUR
Niveau 7
21 décembre 2021 à 11:39:22

Mes VDD ont déjà tout dit, quand tu mets 159,3 en mémoire dans un double, en réalité la valeur représentée est 159.30000000000001136868377216160297393798828125 ( https://baseconvert.com/ieee-754-floating-point ). https://image.noelshack.com/fichiers/2021/51/2/1640083118-screenshot-2021-12-21-at-11-38-21-base-convert-ieee-754-floating-point.png

Bunyan
Bunyan
Niveau 17
21 décembre 2021 à 21:23:16

Un compromis fréquemment utilisé est de multiplier ta valeur par 10 puissance "nombre significatifs" souhaité. L'idée est ainsi de se passer de la mantisse (fréquemment fait pour ce qui est monétaire : échanges et informations en centimes, et c'est passé modifié pour l'affichage).

iks789
iks789
Niveau 26
23 décembre 2021 à 17:33:23

Merci beaucoup pour vos réponse,j'ai corrigé !

Sous forums
  • Aide à l'achat Mac
  • Création de sites web
  • Création de Jeux
  • Linux
  • Programmation
  • Internet
  • Steam Deck
  • Macintosh
  • Hardware
La vidéo du moment