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

Langage Java Discussion :

Multiplication de float [FAQ]


Sujet :

Langage Java

  1. #1
    Membre habitué
    Inscrit en
    Avril 2003
    Messages
    141
    Détails du profil
    Informations forums :
    Inscription : Avril 2003
    Messages : 141
    Points : 128
    Points
    128
    Par défaut Multiplication de float
    Bonjour,
    J ai un petit probleme tout con, si je fait

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
     
    float x = (float) 7.8;
    (x * 3) me donne le resultat 23.400002 et non 23.4 ...
    Voila je sens que la reponse est toute simple, mais je vois pas comment faire arriver a 23.4

  2. #2
    Membre expert

    Homme Profil pro
    Consultant informatique
    Inscrit en
    Janvier 2004
    Messages
    2 301
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Suisse

    Informations professionnelles :
    Activité : Consultant informatique
    Secteur : Finance

    Informations forums :
    Inscription : Janvier 2004
    Messages : 2 301
    Points : 3 675
    Points
    3 675
    Par défaut
    utilise la classe BigDecimal

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
     
    BigDecimal b = new BigDecimal(7.8);
    BigDecimal b2 = b.multiply(new BigDecimal(3));
    cf. http://java.sun.com/j2se/1.4.2/docs/api/java/math/BigDecimal.html

    "Le plug gros problème des citations trouvées sur internet, c'est qu'on ne peut jamais garantir leur authenticité"

    Confucius, 448 av. J-C

  3. #3
    FFF
    FFF est déconnecté
    Membre actif Avatar de FFF
    Profil pro
    Inscrit en
    Mai 2002
    Messages
    342
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Mai 2002
    Messages : 342
    Points : 282
    Points
    282
    Par défaut
    le 3 tout seul est un double pour java par défaut donc crée une autre variable :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
     
    float f1=78.0E-1F;
    float f2=3.0F;

  4. #4
    Gfx
    Gfx est déconnecté
    Expert éminent
    Avatar de Gfx
    Inscrit en
    Mai 2005
    Messages
    1 770
    Détails du profil
    Informations personnelles :
    Âge : 42

    Informations forums :
    Inscription : Mai 2005
    Messages : 1 770
    Points : 8 178
    Points
    8 178
    Par défaut
    Ce n'est pas un probleme inherent a Java mais a la maniere dont les ordinateurs stockent les nombres a virgule flottante. C'est pour ca qu'il faut eviter de faire des tests du genre x == 46.2 ou x est un float ou un double. Si tu veux une precision parfaite, utilise BigDecimal comme l'a dit Pill_S. Dans tous les cas renseigne toi sur la maniere dont sont traites les nombres dans la memoire des ordinateurs. Tu comprendras pourquoi par exemple 65536 * 65536 en Java donne 0 ou encore pourquoi 641 * 6700417 donne 1.
    Romain Guy
    Android - Mon livre - Mon blog

  5. #5
    Membre confirmé Avatar de Satch
    Homme Profil pro
    Hypnothérapeute - Magicien
    Inscrit en
    Mars 2004
    Messages
    498
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 42
    Localisation : Suisse

    Informations professionnelles :
    Activité : Hypnothérapeute - Magicien

    Informations forums :
    Inscription : Mars 2004
    Messages : 498
    Points : 645
    Points
    645
    Par défaut
    faux, le 3 tout seul est converti en float, non pas en double.

    si on avait 3.0 alors oui ça serait un double.

    Et ça ne change de toute façon rien au problème de l'arrondi.

    Il faut soit arrondir à l'aide de la classe Math, soit utiliser la classe BigDecimal.
    En tout cas, je conseille toujours de ne pas utiliser les floats ni les doubles pour faire des calculs, on se retrouve toujours avec des erreurs. A mois de faire super attention... Mais pourquoi s'embêter à faire attention quand on peut faire plus simple ?
    Je sais que désormais vivre est un calembour,
    La mort est devenue un état permanent,
    Le monde est aux fantômes, aux hyènes et aux vautours.
    Moi je vous dis bravo et vive la mort.

  6. #6
    Gfx
    Gfx est déconnecté
    Expert éminent
    Avatar de Gfx
    Inscrit en
    Mai 2005
    Messages
    1 770
    Détails du profil
    Informations personnelles :
    Âge : 42

    Informations forums :
    Inscription : Mai 2005
    Messages : 1 770
    Points : 8 178
    Points
    8 178
    Par défaut
    Ou alors quand on peut tout betement ignorer les erreurs d'arrondi. A moins de realiser une application financiere ou scientifique on peut accepter ces erreurs sans aucun probleme.
    Romain Guy
    Android - Mon livre - Mon blog

  7. #7
    Membre confirmé
    Avatar de Glob
    Homme Profil pro
    Architecte de système d'information
    Inscrit en
    Avril 2002
    Messages
    428
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 47
    Localisation : Suisse

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

    Informations forums :
    Inscription : Avril 2002
    Messages : 428
    Points : 630
    Points
    630
    Par défaut
    Hello.
    Et encore, la seule façon 100% correcte d'initialiser à coup sûr un BigDecimal est de le faire avec un String. Par exemple, "2.0" au lieu de 2.0f.

    L'initialiser avec un nombre peut tout aussi bien se terminer par une erreur d'arrondi
    Glob
    What would you do if you were not afraid?

    Cours et tutoriels pour apprendre Java , FAQ Java, et Forum Java

  8. #8
    FFF
    FFF est déconnecté
    Membre actif Avatar de FFF
    Profil pro
    Inscrit en
    Mai 2002
    Messages
    342
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Mai 2002
    Messages : 342
    Points : 282
    Points
    282
    Par défaut
    2 trois précision pour me "corriger"

    faux, le 3 tout seul est converti en float, non pas en double.
    Oui en fait tu as raison je pense, 3 tout seul n'est pas un double... c'est un int ici mais comme IN est inclu dans IR on fait une conversion implicite int->float (le cour java sun dit : long l=6; //6 est de type int). donc x*3 avec x float te fait une conversion implicite de l'entier 3 en float puisque x est un float, si je comprends bien.

    par contre :
    float f=3.0; est illégal car 3.0 est double effectivement (tiré d'un cour java), il faut écrire "3.0F".

    Moi aussi ça fait plusieurs fois que je me prends la tête sur ces float et double , je viens de faire un petit test qui donne une valeur ""juste"" :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
     
    public class Calcul {
     
    public static void main (String args[]) {
    double d1=7.8;
    double d2=3;
    System.out.println(d1*d2);
    }
    }

  9. #9
    Membre chevronné
    Profil pro
    Inscrit en
    Octobre 2005
    Messages
    940
    Détails du profil
    Informations personnelles :
    Âge : 44
    Localisation : France

    Informations forums :
    Inscription : Octobre 2005
    Messages : 940
    Points : 1 817
    Points
    1 817
    Par défaut
    N'oublions pas la solution la plus simple. Utiliser des doubles plutôt que des floats est suffisant pour la plupart des applications. Si on a besoin d'une précision absolue, il faut utiliser BigDecimal, ailleurs c'est un peu utiliser une bombe atomique pour écraser une puce.

  10. #10
    Membre chevronné
    Homme Profil pro
    Dév. Java & C#
    Inscrit en
    Octobre 2002
    Messages
    1 413
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Suisse

    Informations professionnelles :
    Activité : Dév. Java & C#
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Octobre 2002
    Messages : 1 413
    Points : 1 993
    Points
    1 993
    Par défaut
    Citation Envoyé par Gfx
    Ou alors quand on peut tout betement ignorer les erreurs d'arrondi. A moins de realiser une application financiere ou scientifique on peut accepter ces erreurs sans aucun probleme.
    Par scientifique, tu veux dire mathématique. Car en science ou en ingénieurie, il faut toujours prendre en compte la précision des instruments de mesure. Donc, ce n'est pas des problèmes d'arrondi de moins de 0.1 pour mille d'erreur qui vont donner dul fil à tordre.

    Mais il faut avoir conscience du problème.
    Bien le bonjour chez vous
    Jowo

  11. #11
    Membre confirmé Avatar de Satch
    Homme Profil pro
    Hypnothérapeute - Magicien
    Inscrit en
    Mars 2004
    Messages
    498
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 42
    Localisation : Suisse

    Informations professionnelles :
    Activité : Hypnothérapeute - Magicien

    Informations forums :
    Inscription : Mars 2004
    Messages : 498
    Points : 645
    Points
    645
    Par défaut
    Je dirai même qu'il faut arrondir après CHAQUE opération. Parce qu'une petite erreur trimbalée dans 50 opérations à la suite qui elles même refont des erreurs, ça peut vite devenir catastrophique...
    Je sais que désormais vivre est un calembour,
    La mort est devenue un état permanent,
    Le monde est aux fantômes, aux hyènes et aux vautours.
    Moi je vous dis bravo et vive la mort.

Discussions similaires

  1. Optimisation de la multiplication de deux float
    Par barhili04 dans le forum x86 32-bits / 64-bits
    Réponses: 2
    Dernier message: 28/11/2009, 13h43
  2. Multiplication de float - imprecision
    Par renovati0 dans le forum C
    Réponses: 8
    Dernier message: 14/11/2009, 13h40
  3. Multiplication de Float - Javascript
    Par alex56470 dans le forum Général JavaScript
    Réponses: 5
    Dernier message: 16/01/2009, 05h56
  4. Multiplication de float
    Par xduris dans le forum Langage
    Réponses: 7
    Dernier message: 22/02/2008, 17h11
  5. Multiplication float int
    Par skywaltitou dans le forum MFC
    Réponses: 2
    Dernier message: 29/03/2007, 13h08

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