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 :

comportement bizzare lors d'un test


Sujet :

C

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre confirmé Avatar de Linu6
    Profil pro
    Inscrit en
    Août 2007
    Messages
    227
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Août 2007
    Messages : 227
    Par défaut comportement bizzare lors d'un test
    Ceci est un programme qui enregistre un nom et un mumero de telephone.

    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
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
    26
    27
    28
    29
    30
    31
    32
    33
    34
    35
    36
    37
    38
    39
    40
    41
    42
    void creer(struct Enreg fiche){
         int rep=0; //valeur du test
     
            printf("Sous-Programme création dune fiche.\n");
            printf("Appuyez sur une touche...\n");
            getch();
     
            //saisie du nom et du numero
                 printf("\nSaisir le nom: ");
                 scanf("%s", &fiche.nom);
                 printf("Saisir le numero: ");
                 scanf("%s", &fiche.tel);
     
    //on demande si on veux conserver la fiche ou pas
     
                 printf("Voulez vous conserveez cette fiche(1=yes//0=no): ");
                 scanf("%d", &rep);
       /*si oui , tenter d'ouvrir le fichier*/         
                 if(rep==1){
                 fd=fopen("repertoire.txt", "a+");
    /*echec d'ouverture*/
                 if(fd==NULL){
                         printf("\nError lors de l/'ouverture du fichier spécifié.!\n");
                         }
    /*ouverture réussie, on enregistre les données*/
                         else{
                              fprintf(fd, "%s\n", fiche.nom);
                              fprintf(fd, "%s\n", fiche.tel);
     
                              fclose(fd);
                              printf("Sauvegarde reussie!\n");
                              }
                         }
    /*au cas ou on ne veux pas conserver la fiche*/
     
        else{
             fclose(fd);
             printf("Echec sauvegarde!\n");
             } 
     
                 return;
            }
    mon probleme se situe à ce stade:

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    //on demande si on veux conserver la fiche ou pas
     
                 printf("Voulez vous conserveez cette fiche(1=yes//0=no): ");
                 scanf("%d", &rep);
       /*si oui , tenter d'ouvrir le fichier*/         
                 if(rep==1)
    Ainsi ici "rep" est declaré de type int, et je n'ai pas de probleme.

    mais quand je déclare "rep" de type char, pour qu'on lui affecte la valeur 'y' ou 'n' ...bein ça ne marche pas, le programme s'arrête.

  2. #2
    Expert éminent
    Avatar de Emmanuel Delahaye
    Profil pro
    Retraité
    Inscrit en
    Décembre 2003
    Messages
    14 512
    Détails du profil
    Informations personnelles :
    Âge : 68
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Retraité

    Informations forums :
    Inscription : Décembre 2003
    Messages : 14 512
    Par défaut
    Citation Envoyé par Linu6 Voir le message
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    //on demande si on veux conserver la fiche ou pas
     
                 printf("Voulez vous conserveez cette fiche(1=yes//0=no): ");
                 scanf("%d", &rep);
       /*si oui , tenter d'ouvrir le fichier*/         
                 if(rep==1)
    Ainsi ici "rep" est declaré de type int, et je n'ai pas de probleme.

    mais quand je déclare "rep" de type char, pour qu'on lui affecte la valeur 'y' ou 'n' ...bein ça ne marche pas, le programme s'arrête.
    Normal. Etant donné que "%d" avec scanf() attend l'adresse d'un int, il faut suivre la consigne. Si on fait autre chose, le comportement est indéfini. Point.

  3. #3
    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 : 48
    Localisation : Suisse

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

    Informations forums :
    Inscription : Mai 2005
    Messages : 3 499
    Par défaut
    Citation Envoyé par Linu6 Voir le message
    mais quand je déclare "rep" de type char, pour qu'on lui affecte la valeur 'y' ou 'n' ...bein ça ne marche pas, le programme s'arrête.
    Si tu veux saisir un caractère comme 'y' ou 'n' depuis le flux d'entrée standard, je te conseille de déclarer rep comme étant de type int et d'utiliser la fonction getchar() de la bibliothèque standard. Pour travailler proprement. n'oublie pas de nettoyer le tampon du flux d'entrée standard après l'usage de getchar() (histoire d'éviter les mauvaises surprises).

    Pour étudier le comportement de la fonction getchar() ou fgetc(), je te conseille de lire cet article: http://emmanuel-delahaye.developpez.com/inputs.htm.

    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++

    +

  4. #4
    Membre confirmé Avatar de Linu6
    Profil pro
    Inscrit en
    Août 2007
    Messages
    227
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Août 2007
    Messages : 227
    Par défaut
    Merci pour vos remarques.


  5. #5
    Membre confirmé Avatar de Linu6
    Profil pro
    Inscrit en
    Août 2007
    Messages
    227
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Août 2007
    Messages : 227
    Par défaut
    Euh..au fait le getchar() ne me reussi pas trop.
    Voici mon probleme.

    Toujours dans le meme code, mais dans cette partie cette fois-ci:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    /saisie du nom et du numero
                 printf("\nSaisir le nom: ");
                 scanf("%s", &fiche.nom);
    j'ai voulu modifier l'affectation du nom, pour que celle-ci se fasse caractère par caractère.

    Mais à l'execution, le programme saute le passage de l'affectation du nom.

    Voici mon code.
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    printf("\nSaisir le nom: ");
                 while(c!='\n'){
                 for(i=0; toupper(c=getchar()); i++);
                          fiche.nom[i]=c;
                          }
    où i est une variable locale
    et fiche.nom est un membre d'une structure de ce type:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    struct Enreg{
           char nom[40];
           char tel[10];
           };

  6. #6
    Expert éminent
    Avatar de Emmanuel Delahaye
    Profil pro
    Retraité
    Inscrit en
    Décembre 2003
    Messages
    14 512
    Détails du profil
    Informations personnelles :
    Âge : 68
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Retraité

    Informations forums :
    Inscription : Décembre 2003
    Messages : 14 512
    Par défaut
    Citation Envoyé par Linu6 Voir le message
    Euh..au fait le getchar() ne me reussi pas trop.
    Voici mon probleme.

    Toujours dans le meme code, mais dans cette partie cette fois-ci:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    /saisie du nom et du numero
                 printf("\nSaisir le nom: ");
                 scanf("%s", &fiche.nom);
    j'ai voulu modifier l'affectation du nom, pour que celle-ci se fasse caractère par caractère.

    Mais à l'execution, le programme saute le passage de l'affectation du nom.

    Voici mon code.
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    printf("\nSaisir le nom: ");
                 while(c!='\n'){
                 for(i=0; toupper(c=getchar()); i++);
                          fiche.nom[i]=c;
                          }
    où i est une variable locale
    et fiche.nom est un membre d'une structure de ce type:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    struct Enreg{
           char nom[40];
           char tel[10];
           };
    Comme Thierry se tue à te l'expliquer, quand tu utilises getchar(), il faut ensuite purger le flux. Le bon usage minimum est :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
     
       printf ("Continuer o/n ?\n")
       c = getchar(); /* int c; */
       if (c != '\n')
       {
          while (getchar()) != '\n')
          {
          }
       }
     
       /* agir selon c */
    Evidemment, on ne fait pas ça à chaque fois et on se construit rapidement un fonction de saisie de caractères :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
     
    int get_c(void)
    {
       /* je te laisse completer */
    }
    Qui s'utilise comme ceci :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
     
       printf ("Continuer o/n ?\n")
       c = get_c(); /* int c; */
     
       /* agir selon c */
    Bref, il faut passer un peu de temps à maitriser les I/O en C avant d'écrire une application, sinon, on fonce dans le mur...

    Il faut faire pareil avec les saisies de lignes. Je recommande d'écrire une fonction :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
     
    int get_line(char *s, size_t size)
    {
       int err = 0;
     
       /* a completer */
     
       return err;
    }
    qui s'utilise ainsi (usage minimaliste) :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
     
       /* saisie du nom et du numero */
       printf("Saisir le nom :\n");
       get_line(fiche.nom, sizeof fiche.nom);
       /* etc. */
    Si il faut obtenir une valeur numérique, après un get_line() dans un tableau local (char line[32], par exemple), on fait une conversion avec sscanf() ou strtol(), par exemple.

    on peut aussi construire une fonction de saisie numérique :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
     
    int get_integer (long *p)
    {
       /* etc. */
    }
    Il y a de quoi s'amuser avant d'écrire une application réelle...

  7. #7
    Membre confirmé Avatar de Linu6
    Profil pro
    Inscrit en
    Août 2007
    Messages
    227
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Août 2007
    Messages : 227
    Par défaut
    Je ne comprend pas . ...ca veut pas marcher.

Discussions similaires

  1. Réponses: 3
    Dernier message: 23/06/2008, 15h08
  2. comportement bizzar de mes boutons flash
    Par new-dmx dans le forum Dreamweaver
    Réponses: 10
    Dernier message: 06/12/2007, 10h29
  3. Réponses: 1
    Dernier message: 16/07/2007, 09h54
  4. Réponses: 6
    Dernier message: 19/06/2006, 09h38
  5. Question facile, erreur bizzare lors d'un Left, Top
    Par SpiderAlpha dans le forum C++Builder
    Réponses: 4
    Dernier message: 05/05/2004, 12h56

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