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

 C++ Discussion :

Output de mon code :-1.#IND


Sujet :

C++

  1. #1
    Membre averti
    Profil pro
    Inscrit en
    Mai 2008
    Messages
    31
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Mai 2008
    Messages : 31
    Par défaut Output de mon code :-1.#IND
    Bonjour,

    j'ai écris un code en C++, l' un des résultats (output)que j'avais eu est le suivant:
    ça veux dire quoi svp?
    c'est bizzare,

  2. #2
    Rédacteur
    Avatar de 3DArchi
    Profil pro
    Inscrit en
    Juin 2008
    Messages
    7 634
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juin 2008
    Messages : 7 634
    Par défaut
    NaN.
    Ton calcul échoue (par exemple sqrt(-1) retourne NaN).

  3. #3
    Membre éclairé Avatar de befalimpertinent
    Profil pro
    Inscrit en
    Avril 2007
    Messages
    561
    Détails du profil
    Informations personnelles :
    Âge : 41
    Localisation : France, Gironde (Aquitaine)

    Informations forums :
    Inscription : Avril 2007
    Messages : 561
    Par défaut
    ça sent la division par zero.
    Postes le bout de code qui provoque cette sortie pour qu'on puisse t'en dire plus

  4. #4
    Rédacteur/Modérateur
    Avatar de JolyLoic
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Août 2004
    Messages
    5 463
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 50
    Localisation : France, Yvelines (Île de France)

    Informations professionnelles :
    Activité : Développeur informatique
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Août 2004
    Messages : 5 463
    Par défaut
    Une division par 0 donnerait un infini, pas un NAN.
    Ma session aux Microsoft TechDays 2013 : Développer en natif avec C++11.
    Celle des Microsoft TechDays 2014 : Bonnes pratiques pour apprivoiser le C++11 avec Visual C++
    Et celle des Microsoft TechDays 2015 : Visual C++ 2015 : voyage à la découverte d'un nouveau monde
    Je donne des formations au C++ en entreprise, n'hésitez pas à me contacter.

  5. #5
    Inactif  
    Profil pro
    Inscrit en
    Juillet 2005
    Messages
    1 958
    Détails du profil
    Informations personnelles :
    Âge : 60
    Localisation : France

    Informations forums :
    Inscription : Juillet 2005
    Messages : 1 958
    Par défaut
    Citation Envoyé par Udani Voir le message
    Bonjour,

    j'ai écris un code en C++, l' un des résultats (output)que j'avais eu est le suivant:
    ça veux dire quoi svp?
    c'est bizzare,
    C'est la manière dont Microsoft signale un "Quiet NaN". Tu pourras trouver un peu d'explication ici : http://www.cisl.ucar.edu/docs/trap.e...rrortypes.html
    Tu as fait une opération qui ne mène pas à un nombre. 3DArchi t'en donnes un exemple. Ça n'a rien de bizarre donc.

    Vérifies tes calculs au fur et à mesure, quitte à placer des asserts avant les opérations sensibles. Une bonne activité de débuggage en vue donc.

  6. #6
    Inactif  
    Profil pro
    Inscrit en
    Juillet 2005
    Messages
    1 958
    Détails du profil
    Informations personnelles :
    Âge : 60
    Localisation : France

    Informations forums :
    Inscription : Juillet 2005
    Messages : 1 958
    Par défaut
    Citation Envoyé par befalimpertinent Voir le message
    ça sent la division par zero.
    Postes le bout de code qui provoque cette sortie pour qu'on puisse t'en dire plus
    Mauvaise idée. Il faut qu'il cherche par lui-même. Si on l'aide, il retombera dans le piège la prochaine fois. S'il en bave, il va s'en souvenir

  7. #7
    Membre averti
    Profil pro
    Inscrit en
    Mai 2008
    Messages
    31
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Mai 2008
    Messages : 31
    Par défaut
    Merci pour vous réponses. En effet il s'agit d' un valeur "qui n' est pas bonne" et qui est presque nul. J'ai utilisé un autre compiler ( DevC++ au lieu de Visual C++ 2005 express ) qui a donné une valeur qui est : 2.23237e-307 !!!
    je vais essayer de vous poster la partie du code concernée.
    Mais avant je tiens à vous informer que j'ai pas encore compris ce que fait le debbugeur. Serais t-il possible de connaitre la partie de ma méthode qui est la cause de mon malheur ? comment ? aidez moi svp!

  8. #8
    Expert éminent
    Avatar de koala01
    Homme Profil pro
    aucun
    Inscrit en
    Octobre 2004
    Messages
    11 644
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 53
    Localisation : Belgique

    Informations professionnelles :
    Activité : aucun

    Informations forums :
    Inscription : Octobre 2004
    Messages : 11 644
    Par défaut
    Salut,

    D'après ce que tu écris, j'aurais tendance à dire que tu essaye de faire une opération mathématique (sans doute une division) avec des valeurs dont l'une au moins n'est pas correctement initialisée.

    Si tu travailles avec des structures (ou des classes) pense à respecter scrupuleusement le principe du RAII (Ressource Aquisition Is Initialisation, ou, si tu préfères en français : l'acquisition de ressources est l'initialisation).

    Si tu travailles avec des pointeurs, veilles à bien utiliser la valeur "pointée par" ton pointeur, car, autrement, la valeur utilisée sera... le résultat de la conversion de l'adresse en valeur, et tu aura compris que ce n'est sans doute pas ce que tu veux faire

    Si, enfin, tu travailles "simplement" avec des variables de types "primitifs", veille à ce que leur valeur soient "cohérentes" avec ce à quoi elles servent.

    Peut être devrais tu régler ton compilateur sur un mode "paranoïac" et veiller à trouver une solution pour supprimer chaque avertissement qu'il t'affiche (en commençant par le premier, car il y en a parfois "en cascade" )
    A méditer: La solution la plus simple est toujours la moins compliquée
    Ce qui se conçoit bien s'énonce clairement, et les mots pour le dire vous viennent aisément. Nicolas Boileau
    Compiler Gcc sous windows avec MinGW
    Coder efficacement en C++ : dans les bacs le 17 février 2014
    mon tout nouveau blog

  9. #9
    Inactif  
    Profil pro
    Inscrit en
    Juillet 2005
    Messages
    1 958
    Détails du profil
    Informations personnelles :
    Âge : 60
    Localisation : France

    Informations forums :
    Inscription : Juillet 2005
    Messages : 1 958
    Par défaut
    Citation Envoyé par Udani Voir le message
    [...]
    je vais essayer de vous poster la partie du code concernée.
    Mais avant je tiens à vous informer que j'ai pas encore compris ce que fait le debbugeur. Serais t-il possible de connaitre la partie de ma méthode qui est la cause de mon malheur ? comment ? aidez moi svp!
    Tu n'as pas besoin d'un débuggeur: apprends à tracer toi même ton programme avant d'utiliser un débuggeur (et par la suite, apprends à utiliser un débuggeur pour ne pas galerer bêtement). Place régulièrement dans ton programme des affichages aux points sensibles. Tu verras avec quelles valeurs tu fais ton calcul. C'est long, pénible et error-prone lorsque tu les enlèves. Mais c'est un bon apprentissage.

    Comme je l'ai dit tu peux aussi ajouter des asserts (#include <cassert>)
    Code c++ : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
     
    resultat = sqrt(valeur) / coefficient ;
    deviendrait, par exemple,
    Code c++ : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
     
    assert (valeur > 0);
    assert (coefficient != 0);
    resultat = sqrt(valeur) / coefficient ;
    dépendant de ce que tu penses avoir à ce moment du code. Ceci à l'avantage de ne pas demander de modifications de code une fois que tu as fini. Pour ne pas tenir compte des asserts tu rajoutes
    juste avant l'include.

    Citation Envoyé par koala01 Voir le message
    [...]
    Peut être devrais tu régler ton compilateur sur un mode "paranoïac" et veiller à trouver une solution pour supprimer chaque avertissement qu'il t'affiche (en commençant par le premier, car il y en a parfois "en cascade" )
    C'est un très bon conseil. J'impose toujours à mes étudiants de mettre le maximum d'avertissement (option --Wall) et tous les enlever. Quand on fait des programmes de débutant, on devrait toujours pouvoir le faire.

  10. #10
    Membre éclairé Avatar de befalimpertinent
    Profil pro
    Inscrit en
    Avril 2007
    Messages
    561
    Détails du profil
    Informations personnelles :
    Âge : 41
    Localisation : France, Gironde (Aquitaine)

    Informations forums :
    Inscription : Avril 2007
    Messages : 561
    Par défaut
    Place régulièrement dans ton programme des affichages aux points sensibles
    Pas d'accord, modifier le contexte autour de l'erreur c'est la meilleur façon de la perdre. Apprendre à utiliser un debugeur est le meilleur conseil qu'on puisse lui donner.
    Avec VS, par exemple, places un point d'arret à un endroit suspect (F9), exécutes en mode Debug ton programme et vérifies les valeurs en exécutant ton code pas à pas(F10) . ça ne devrait par résister trop longtemps.

  11. #11
    Expert confirmé

    Inscrit en
    Novembre 2005
    Messages
    5 145
    Détails du profil
    Informations forums :
    Inscription : Novembre 2005
    Messages : 5 145
    Par défaut
    Citation Envoyé par befalimpertinent Voir le message
    Apprendre à utiliser un debugeur est le meilleur conseil qu'on puisse lui donner.
    Je crois que les opinions varient. Apprendre a se passer du debugueur est a mon avis un meilleur conseil que d'apprendre a s'en servir.

    Je ne suis pas de ceux qui les prétendent inutiles mais leur utilité est plus limitée que ne l'affirment ceux qui les prétendent indispensables. Ils sont souvent aussi une perte de temps énorme quand ils ne sont pas la meilleure technique.

  12. #12
    Rédacteur
    Avatar de 3DArchi
    Profil pro
    Inscrit en
    Juin 2008
    Messages
    7 634
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juin 2008
    Messages : 7 634
    Par défaut
    Citation Envoyé par Jean-Marc.Bourguet Voir le message
    Je crois que les opinions varient.
    Effectivement, c'est presque du domaine du troll. A mon sens, si tu maîtrise le debugger, utilise-le de façon privilégiée. Sinon, les bonnes vieilles traces ont aussi du bon. Mais c'est souvent plus laborieux. Mais avant de préférer l'un à l'autre, autant maîtriser son environnement de dev.

  13. #13
    Expert confirmé

    Inscrit en
    Novembre 2005
    Messages
    5 145
    Détails du profil
    Informations forums :
    Inscription : Novembre 2005
    Messages : 5 145
    Par défaut
    Citation Envoyé par 3DArchi Voir le message
    Effectivement, c'est presque du domaine du troll. A mon sens, si tu maîtrise le debugger, utilise-le de façon privilégiée. Sinon, les bonnes vieilles traces ont aussi du bon. Mais c'est souvent plus laborieux. Mais avant de préférer l'un à l'autre, autant maîtriser son environnement de dev.
    Bizarre, mon point de vue est que le debugeur est souvent plus laborieux au final. Plus incremental, donc on veut voir tout de suite et on réfléchit moins a l'aspect d'ensemble; or c'est en reflechissant qu'on trouve les problemes. Ca tient aussi a la nature des bugs recherche -- les miens sont souvent des interactions subtiles ou une vision trop pres du code n'indique pas la nature reelle du probleme.

  14. #14
    Rédacteur
    Avatar de 3DArchi
    Profil pro
    Inscrit en
    Juin 2008
    Messages
    7 634
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juin 2008
    Messages : 7 634
    Par défaut
    Citation Envoyé par Jean-Marc.Bourguet Voir le message
    Bizarre, mon point de vue est que le debugeur est souvent plus laborieux au final. Plus incremental, donc on veut voir tout de suite et on réfléchit moins a l'aspect d'ensemble; or c'est en reflechissant qu'on trouve les problemes. Ca tient aussi a la nature des bugs recherche -- les miens sont souvent des interactions subtiles ou une vision trop pres du code n'indique pas la nature reelle du probleme.
    A la réflexion, tu as raison au moins à 50%. Mon expérience m'a plutôt amené à penser que 80% de bugs sont dus à des lacunes en tests unitaires, et donc on les trouves plus facilement avec le debugger. Mais là où je te rejoint, c'est que les bugs subtils (multi-thread, réseau, dynamique d'échange de messages windows ...) sont en général plus facilement diagnostiqués en analysant la dynamique d'ensemble avec des traces.

Discussions similaires

  1. Mon code n'est pas interprété !
    Par korriganez dans le forum Langage
    Réponses: 3
    Dernier message: 31/05/2006, 15h46
  2. [Exécutable]puis je creer un executable a partir de mon code ?
    Par youpileouf dans le forum Général Java
    Réponses: 3
    Dernier message: 17/06/2005, 09h15
  3. Optimiser mon code ASP/HTML
    Par ahage4x4 dans le forum ASP
    Réponses: 7
    Dernier message: 30/05/2005, 10h29
  4. Réponses: 1
    Dernier message: 21/02/2005, 12h40
  5. [langage] algo de bissection dans mon code
    Par killy dans le forum Langage
    Réponses: 5
    Dernier message: 19/01/2004, 18h35

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