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 :

Scanf dans une boucle while


Sujet :

C

  1. #1
    Candidat au Club
    Inscrit en
    Février 2008
    Messages
    3
    Détails du profil
    Informations forums :
    Inscription : Février 2008
    Messages : 3
    Points : 2
    Points
    2
    Par défaut Scanf dans une boucle while
    Bonjour à tous,
    J'aurai besoin d'un éclairciceemnt à propos d'un petit bout de code.
    Je n'arrive décidemment pas à comprendre pourquoi cela ne marche pas


    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
     
    char * reponse = malloc(TAILLE*sizeof(char));
    assert(reponse);
    while((strcmp(reponse, "yes") != 0) || (strcmp(reponse, "no") != 0))
    {
       printf(" (yes or no) \n");
       scanf("%s", reponse);
    }
    Je veux faire une interface interactive, qui lorsque que je lui donne "yes" ou "no", execute la partie du code que je veux. Or ici, lorsque j'execute, il ne sort jamais de la boucle while, et me re balance toujours le printf et scanf.
    GDB ne m'a pas aidé à comprendre le pourquoi du comment


    Aidez moi siouplez . Merci d'avance


    ~~~~~~~EDIT~~~~~~~~~
    Ci dessous le code résolu et sans erreur :


    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
     
    char * reponse = malloc(TAILLE*sizeof(char));
    assert(reponse);
    reponse = strcpy(reponse, "huhu");
     
    while((strcmp(reponse, "yes") != 0) && (strcmp(reponse, "no") != 0))
    {
       printf(" (yes or no) ");
       scanf("%s", reponse);
    }

  2. #2
    Rédacteur/Modérateur
    Avatar de Trap D
    Profil pro
    Inscrit en
    Septembre 2003
    Messages
    4 942
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Septembre 2003
    Messages : 4 942
    Points : 6 498
    Points
    6 498
    Par défaut
    le scanf est TRRRRRRRRRRRRREEEEEEEEEEEEEEEEEEEESSSSSSSSSS difficile à utiliser, surtout pour un débutant.
    Utilise fgets(buf, sizeof buf, stdin) puis vire le '\n' de fin de saisie.
    Fais une recherche dans la FAQ.
    De plus tu as un problème de logique dans ton code, réfléchis bien à ce que tu écris avec le ||
    "La haine seule fait des choix" - Koan Zen
    "Il ne faut pas être meilleur que les autres, il faut être meilleur que soi." Albert Jacquard
    "Ceux qui savent où ils ont posé leur parapluie ne sont pas alcooliques." - pgibonne.
    Faites du Prolog, ça vous changera les idées !
    Ma page Prolog
    Mes codes sources commentés

    Mon avatar : La Madeleine à la veilleuse de Georges de La Tour

  3. #3
    Expert éminent sénior
    Avatar de diogene
    Homme Profil pro
    Enseignant Chercheur
    Inscrit en
    Juin 2005
    Messages
    5 761
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Essonne (Île de France)

    Informations professionnelles :
    Activité : Enseignant Chercheur
    Secteur : Enseignement

    Informations forums :
    Inscription : Juin 2005
    Messages : 5 761
    Points : 13 926
    Points
    13 926
    Par défaut
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    char * reponse = malloc(TAILLE*sizeof(char));
    assert(reponse);
    while((strcmp(reponse, "yes") != 0) || (strcmp(reponse, "no") != 0))
    {...
    - Au moment où on entre la première fois dans le while, le contenu du tableau pointé par reponse est non initialisé et la comparaison n'a pas de sens. Utiliser plutôt un do ... while.

    - Revoir la logique de la combinaison xxx || yyy :
    Si reponse est "yes" alors yyy est vrai
    Si reponse est "no" alors xxx est vrai
    Si reponse est autre chose alors xxx et yyy sont vrais
    Dans tout les cas xxx || yyy est vrai
    Publication : Concepts en C

    Mon avatar : Glenn Gould

    --------------------------------------------------------------------------
    Une réponse vous a été utile ? Remerciez son auteur en cliquant le pouce vert !

  4. #4
    Candidat au Club
    Inscrit en
    Février 2008
    Messages
    3
    Détails du profil
    Informations forums :
    Inscription : Février 2008
    Messages : 3
    Points : 2
    Points
    2
    Par défaut
    D'abord merci pour vos réponses.

    Citation Envoyé par diogene Voir le message
    - Au moment où on entre la première fois dans le while, le contenu du tableau pointé par reponse est non initialisé et la comparaison n'a pas de sens.
    J'ai donc initialisé ma variable à "huhu", histoire d'avoir quelquechose dedans.


    Citation Envoyé par diogene
    - Revoir la logique de la combinaison xxx || yyy :
    Si reponse est "yes" alors yyy est vrai
    Si reponse est "no" alors xxx est vrai
    Si reponse est autre chose alors xxx et yyy sont vrais
    Dans tout les cas xxx || yyy est vrai
    Oups, petite erreur de logique . J'ai remplacé mes "||" par "&&".


    Et du coup, ca marche du tonnerre

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
     
    char * reponse = malloc(TAILLE*sizeof(char));
    assert(reponse);
    reponse = strcpy(reponse, "huhu");
     
    while((strcmp(reponse, "yes") != 0) && (strcmp(reponse, "no") != 0))
    {
       printf(" (yes or no) ");
       scanf("%s", reponse);
    }

    J'édite mon premier post.

    Merci à tous.

  5. #5
    Expert confirmé
    Avatar de Thierry Chappuis
    Homme Profil pro
    Enseignant Chercheur
    Inscrit en
    Mai 2005
    Messages
    3 499
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 47
    Localisation : Suisse

    Informations professionnelles :
    Activité : Enseignant Chercheur
    Secteur : Industrie Pharmaceutique

    Informations forums :
    Inscription : Mai 2005
    Messages : 3 499
    Points : 5 360
    Points
    5 360
    Par défaut
    Citation Envoyé par DreakY Voir le message
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
     
    char * reponse = malloc(TAILLE*sizeof(char));
    assert(reponse);
    while((strcmp(reponse, "yes") != 0) || (strcmp(reponse, "no") != 0))
    {
       printf(" (yes or no) \n");
       scanf("%s", reponse);
    }
    assert() pour faire le test de la valeur retournée par malloc(), c'est pas terrible...

    Thierry
    "The most important thing in the kitchen is the waste paper basket and it needs to be centrally located.", Donald Knuth
    "If the only tool you have is a hammer, every problem looks like a nail.", probably Abraham Maslow

    FAQ-Python FAQ-C FAQ-C++

    +

  6. #6
    Expert éminent sénior
    Avatar de Médinoc
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Septembre 2005
    Messages
    27 369
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 40
    Localisation : France

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

    Informations forums :
    Inscription : Septembre 2005
    Messages : 27 369
    Points : 41 519
    Points
    41 519
    Par défaut
    En effet. Un assertion ne sert pas à ça, un échec de malloc() n'est PAS une erreur de logique.
    SVP, pas de questions techniques par MP. Surtout si je ne vous ai jamais parlé avant.

    "Aw, come on, who would be so stupid as to insert a cast to make an error go away without actually fixing the error?"
    Apparently everyone.
    -- Raymond Chen.
    Traduction obligatoire: "Oh, voyons, qui serait assez stupide pour mettre un cast pour faire disparaitre un message d'erreur sans vraiment corriger l'erreur?" - Apparemment, tout le monde. -- Raymond Chen.

  7. #7
    Candidat au Club
    Inscrit en
    Février 2008
    Messages
    3
    Détails du profil
    Informations forums :
    Inscription : Février 2008
    Messages : 3
    Points : 2
    Points
    2
    Par défaut
    Citation Envoyé par Médinoc Voir le message
    En effet. Un assertion ne sert pas à ça, un échec de malloc() n'est PAS une erreur de logique.
    Citation Envoyé par Thierry Chappuis Voir le message
    assert() pour faire le test de la valeur retournée par malloc(), c'est pas terrible...
    Thierry
    Pourtant c'est ce qu'on nous a appris en cours =/
    On nous a dit que c'est pour confirmer que notre pointeur a bien été alloué dans la mémoire.

    Vous proposez quoi à la place ?

  8. #8
    Rédacteur/Modérateur
    Avatar de Trap D
    Profil pro
    Inscrit en
    Septembre 2003
    Messages
    4 942
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Septembre 2003
    Messages : 4 942
    Points : 6 498
    Points
    6 498
    Par défaut
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    if (reponse == NULL)
    {
      // prendre les mesures appropriées à la situation
      // et sans doute
      return <code_erreur>; 
    }
    "La haine seule fait des choix" - Koan Zen
    "Il ne faut pas être meilleur que les autres, il faut être meilleur que soi." Albert Jacquard
    "Ceux qui savent où ils ont posé leur parapluie ne sont pas alcooliques." - pgibonne.
    Faites du Prolog, ça vous changera les idées !
    Ma page Prolog
    Mes codes sources commentés

    Mon avatar : La Madeleine à la veilleuse de Georges de La Tour

  9. #9
    Expert confirmé
    Avatar de Thierry Chappuis
    Homme Profil pro
    Enseignant Chercheur
    Inscrit en
    Mai 2005
    Messages
    3 499
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 47
    Localisation : Suisse

    Informations professionnelles :
    Activité : Enseignant Chercheur
    Secteur : Industrie Pharmaceutique

    Informations forums :
    Inscription : Mai 2005
    Messages : 3 499
    Points : 5 360
    Points
    5 360
    Par défaut
    Citation Envoyé par DreakY Voir le message
    Pourtant c'est ce qu'on nous a appris en cours =/
    On nous a dit que c'est pour confirmer que notre pointeur a bien été alloué dans la mémoire.
    C'est une grosse erreur. Si la macro NDEBUG est définie, assert() ne fait rien et l'échec de malloc() n'est plus détecté ni traité. La forme canonique pour l'usage de malloc est:

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    Type *p = NULL;
    /*...*/
    p = malloc(TAILLE  * sizeof *p);
    if (p != NULL)
    {
        /* L'allocation a reussi: on continue */
     
        /* On libere la memoire allouee par malloc() et on affecte une adresse
            invalide testable (NULL) a la variable p */
        free(p), p = NULL;
    }
    else
    {
        /* Gestion de l'erreur */
    }
    Thierry
    "The most important thing in the kitchen is the waste paper basket and it needs to be centrally located.", Donald Knuth
    "If the only tool you have is a hammer, every problem looks like a nail.", probably Abraham Maslow

    FAQ-Python FAQ-C FAQ-C++

    +

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

Discussions similaires

  1. [Tkinter] Méthode get() dans une boucle while
    Par Thundie dans le forum Tkinter
    Réponses: 2
    Dernier message: 04/02/2006, 00h06
  2. Problème de SCANF dans une boucle WHILE
    Par FidoDido® dans le forum C
    Réponses: 4
    Dernier message: 30/12/2005, 17h42
  3. [Conception] Problème de test dans une boucle while
    Par Cyrius dans le forum PHP & Base de données
    Réponses: 2
    Dernier message: 26/11/2005, 18h07
  4. Réponses: 6
    Dernier message: 17/06/2005, 16h51
  5. [MFC] Dialog dans une boucle while
    Par oxor3 dans le forum MFC
    Réponses: 5
    Dernier message: 23/04/2004, 22h51

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