IdentifiantMot de passe
Loading...
Mot de passe oublié ?Je m'inscris ! (gratuit)
Navigation

Inscrivez-vous gratuitement
pour pouvoir participer, suivre les réponses en temps réel, voter pour les messages, poser vos propres questions et recevoir la newsletter

Android Discussion :

Problème d'arrondi


Sujet :

Android

  1. #1
    Nouveau Candidat au Club
    Profil pro
    Inscrit en
    Mai 2012
    Messages
    2
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Mai 2012
    Messages : 2
    Points : 1
    Points
    1
    Par défaut Problème d'arrondi
    Hello,

    Je dois développer un projet sur android et je bute sur un très simple problème de multiplication Java.

    En gros j'ai à peu près le code basique ci-après:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
     
    Float a,b,c;
     
    a=new Float("25,35");
    b=new Float("6,5");
     
    c=a*b; 
     
    Log.i("",c.toString());// Résultat c=164,77501
    Ma question étant pourquoi il m'affiche 164,77501 comme résultat sachant qu'une simple calculatrice me retourne bien 164,775.

    D'où vient ce petit résidu de 0,00001 ??? Je ne suis pas pro Java mais ça ne m'a pourtant pas l'air bien compliqué de faire faire une multiplication à la machine... Ou alors c'est mon utilisation du type Float ???

  2. #2
    Modérateur

    Avatar de Robin56
    Homme Profil pro
    Architecte de système d'information
    Inscrit en
    Juin 2009
    Messages
    5 297
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Ille et Vilaine (Bretagne)

    Informations professionnelles :
    Activité : Architecte de système d'information

    Informations forums :
    Inscription : Juin 2009
    Messages : 5 297
    Points : 13 670
    Points
    13 670
    Par défaut
    Va voir ce post qui t'expliquera ça en détails.
    Responsable Java de Developpez.com (Twitter et Facebook)
    Besoin d'un article/tutoriel/cours sur Java, consulter la page cours
    N'hésitez pas à consulter la FAQ Java et à poser vos questions sur les forums d'entraide Java
    --------
    Architecte Solution
    LinkedIn : https://www.linkedin.com/in/nicolascaudard/

  3. #3
    Nouveau Candidat au Club
    Profil pro
    Inscrit en
    Mai 2012
    Messages
    2
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Mai 2012
    Messages : 2
    Points : 1
    Points
    1
    Par défaut
    ok merci pour le lien, je vais tester ça mais bizarre quand même cette histoire d'approximation de calcul qui ressort à l'affichage...

  4. #4
    Expert éminent

    Homme Profil pro
    Ingénieur systèmes et réseaux
    Inscrit en
    Février 2007
    Messages
    4 253
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Rhône (Rhône Alpes)

    Informations professionnelles :
    Activité : Ingénieur systèmes et réseaux
    Secteur : High Tech - Multimédia et Internet

    Informations forums :
    Inscription : Février 2007
    Messages : 4 253
    Points : 7 618
    Points
    7 618
    Billets dans le blog
    3
    Par défaut
    pas tant que ça....

    25,35 ne peut pas s'écrire en binaire:
    11001.0101100110011001100....
    réprésentation float IEEE:
    2E4 x (1.) 100101011001100110011001

    6,5 c'est en binaire:
    110.1
    en float IEEE:
    2E2 x (1.) 101000000000000000000

    si on multiplie les deux:
    2E6 x (1.) 100101011001100110011001
    + 2E6 x (0.) 110010101100110011001100
    + 2E6 x (0.) 001100101011001100110011
    =
    2E7 x (1.) 010010011000110011001101 <= arrondi automatique puisque '011' !

    soit 164.77500152587890625


    Ensuite on passe par Float.toString() qui fait appel à RealToString.floatToString() optimisé pour aller vite (et pas faire des rendus exacts) => bim... 164.77501


    Si on veut des calcules exacts, utiliser BigDecimal par exemple....
    N'oubliez pas de cliquer sur mais aussi sur si un commentaire vous a été utile !
    Et surtout

Discussions similaires

  1. Problème d'arrondi
    Par rigobert dans le forum C
    Réponses: 28
    Dernier message: 05/04/2006, 12h56
  2. problème d'arrondi à 2 chiffres après virgule
    Par nerick dans le forum Langage
    Réponses: 1
    Dernier message: 05/01/2006, 17h26
  3. Problème d'arrondis
    Par steps5ive dans le forum Access
    Réponses: 5
    Dernier message: 09/12/2005, 17h35
  4. [DECIMAL] problème d'arrondi
    Par Boosters dans le forum SQL Procédural
    Réponses: 1
    Dernier message: 28/11/2005, 15h30
  5. Problème d'arrondi
    Par ptitsoleil87 dans le forum Général JavaScript
    Réponses: 4
    Dernier message: 07/01/2005, 09h37

Partager

Partager
  • Envoyer la discussion sur Viadeo
  • Envoyer la discussion sur Twitter
  • Envoyer la discussion sur Google
  • Envoyer la discussion sur Facebook
  • Envoyer la discussion sur Digg
  • Envoyer la discussion sur Delicious
  • Envoyer la discussion sur MySpace
  • Envoyer la discussion sur Yahoo