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

Windows Forms Discussion :

Un calcul qui perd la boule


Sujet :

Windows Forms

  1. #1
    Membre actif
    Homme Profil pro
    Développeur .NET
    Inscrit en
    Septembre 2003
    Messages
    399
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Développeur .NET

    Informations forums :
    Inscription : Septembre 2003
    Messages : 399
    Points : 259
    Points
    259
    Par défaut Un calcul qui perd la boule
    bonjour,

    le code suivant perd la boule !

    pour info toutes les variables sont des doubles
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    Dim SommeRajouté As Double = (MontantTcc - SumOpération)
    voici en valeur ce que je devrais obtenir
    990.0 - 946.2 = 43.8

    et voici ce que j'ai
    990.0 - 946.2 = 43.799999999999955

    par contre j'ai la bonne valeur en rajoutant le ToString

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    Dim SommeRajouté As Double = (MontantTcc - SumOpération).ToString
    je trouve ça moche mais avant tout je voudrais comprend ce qui se passe.


    rajout : les valeurs sont prises de la fenêtre espion et non d'un pseudo calcul de tête.

  2. #2
    Expert éminent sénior

    Avatar de Philippe Vialatte
    Homme Profil pro
    Architecte technique
    Inscrit en
    Juillet 2004
    Messages
    3 029
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 46
    Localisation : France, Alpes Maritimes (Provence Alpes Côte d'Azur)

    Informations professionnelles :
    Activité : Architecte technique
    Secteur : High Tech - Produits et services télécom et Internet

    Informations forums :
    Inscription : Juillet 2004
    Messages : 3 029
    Points : 12 465
    Points
    12 465
    Par défaut
    Salut,

    990.0 - 946.2 = 43.799999999999955
    c'est normal...tu utilise un type double

    Le type double ne stocke pas les informations precisement, je pourrais gratter un peu pour retrouver un article quelconque, mais grosso modo, Double et FLoat sont des types a utiliser pour des operations "physiques", et pas forcement "mathématiques"

    je trouve ça moche mais avant tout je voudrais comprend ce qui se passe.
    Dans ton exemple, tu prends un resultat en double (qui est le resultat d'une soustraction de deux nombres "imprecis"), que tu castes explicitement en String, et que tu recastes implicitement en double.

    Du coup, comme par defaut, le Tostring va faire un arrondi au deuxieme chiffre, ca sembe etre un bon resultat...mais ce n'est absolument pas fiable

    La "bonne" solution, ce serait, dans un premier temps, de passer en mode strict (parce que les casts a l'arrache comme ca, c'est mal), et, dans un second temps, d'utiliser le type decimal si tu dois gerer des operations de ce genre

  3. #3
    Membre actif
    Homme Profil pro
    Développeur .NET
    Inscrit en
    Septembre 2003
    Messages
    399
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Développeur .NET

    Informations forums :
    Inscription : Septembre 2003
    Messages : 399
    Points : 259
    Points
    259
    Par défaut
    je connaissais pas cette subtilité !

    Tu es trop fort

    merci !

    ps : je cherche une corde et une poutre !

+ Répondre à la discussion
Cette discussion est résolue.

Discussions similaires

  1. [Excel] Bouton qui perd son nom
    Par steps5ive dans le forum Excel
    Réponses: 2
    Dernier message: 21/03/2007, 13h42
  2. Variable qui perd sa valeur
    Par thierry-69007 dans le forum Delphi
    Réponses: 5
    Dernier message: 14/12/2006, 13h18
  3. Réponses: 4
    Dernier message: 05/12/2006, 11h52
  4. Calcul qui ne marche pas
    Par BoNux83 dans le forum Langage
    Réponses: 8
    Dernier message: 15/10/2006, 02h48
  5. Un calcul qui ne fonctionne pas
    Par renaud26 dans le forum Général JavaScript
    Réponses: 3
    Dernier message: 29/06/2006, 14h21

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