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

Java arrondir float

ScottBrendo
ScottBrendo
Niveau 7
18 octobre 2014 à 12:42:01

Bonjour, lorsque j’incrémente des float dans une boucle, je remarque que celui ci prend plusieurs decimale. Par exemple quand j'incrémente de 0,1 j'ai ça :

0.1
0.2
0.3
0.4
0.5
0.6
0.70000005
0.8000001
0.9000001

j'aimerai conserver une décimale.

Par avance merci :)

ScottBrendo
ScottBrendo
Niveau 7
18 octobre 2014 à 12:44:05

J'ai fais un truc comme ça : , ca

Float.valueOf(df.format(maValeur).replace(',', '.')

Ça fonctionne, mais il doit y avoir beaucoup plus simple non :question:

Pseudo supprimé
Pseudo supprimé 18 octobre 2014 à 14:16:34

C'est pour de l'affichage ou du calcul ?

Si c'est pour de l'affichage, oui, il faut passer par un formatage du genre 'new DecimalFormat("#.#")' et d'y appliquer la précision que tu souhaites.

Si c'est pour de calcul... Reuuuuuuuh ! Alerte rouge ! Touche pas à ça :D Les flottants sont imprécis par nature, certaines valeurs n'existent pas (Les réels sont infinis et non dénombrables, tu ne pourras jamais représenter avec un nombre fini de bits une infinité de valeurs). Ce que tu vois lors de tes incrémentations, c'est la manifestation de cette imprécision :)

JustAnIllusion
JustAnIllusion
Niveau 9
18 octobre 2014 à 16:19:14

D'accord merci, donc pas de calcul avec des flottants ?

Shippeur
Shippeur
Niveau 8
18 octobre 2014 à 16:44:45

Tu peux utiliser des libs externes comme JScience, Apfloat ou DFP

Pseudo supprimé
Pseudo supprimé 18 octobre 2014 à 22:30:44

JustAnIllusion :d) Arf :D Rassure-toi, je disais juste qu'il ne fallait pas approximer des flottants que tu souhaites utiliser pour des calculs : ça amplifie l'erreur. Tu peux très bien les utiliser, c'est lorsque tu es sur des problématiques très avancées que tu vas rencontrer des problèmes (et sur les frontières de la précision, genre, grand nombre, mais précision pourrie). Dans ce cas-là, oui, tu passeras sur des bibliothèques dédiées. Pour faire des jeux ou des calculs à la con, les flottants et les doubles suffisent largement :)

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