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 :

Bus error et strcmp


Sujet :

C

  1. #1
    Nouveau membre du Club
    Profil pro
    Inscrit en
    Novembre 2007
    Messages
    55
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Novembre 2007
    Messages : 55
    Points : 39
    Points
    39
    Par défaut Bus error et strcmp
    Bonjour,

    j'ai un petit soucis avec la fonction strcmp qui me lance un "Bus error"

    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
     
    #include <stdio.h> 
    #include <string.h>
     
    int main(void)
    {
      puts("Running");
     
      char* s;
     
      while(1) {
        puts("mydevice> ");
        fgets(s, 10, stdin);
     
        if ( strcmp(s,"IDN")==0 ) {
          puts("*IDN? identification \r\n");
        } else {
          puts("Error ! this firmware doesn't understand this command\r\n");
        }
      }
     
      puts("Stopping\r\n"); /* it should never happen */
     
      return 0;
    }
    Avez-vous une idée d'où peut venir mon problème (ça fait un petit moment que je tourne autour sans le voir... ?


    tant que j'y suis
    je compile avec gcc avec les flags -ansi -pedantic -Wall
    et j'ai le warning suivant à la compilation :
    warning: ISO C90 forbids mixed declarations and code
    c'est à cause de char* s; mais je ne vois pas en quoi je mélange
    code et déclaration...

    ... pour cette deuxième partie j'ai vu... il suffit que je place ma déclaration avant la fonction main


    Merci d'avance

  2. #2
    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
      char* s;
    ....
        fgets(s, 10, stdin);
    s doit être un tableau de caractères, pas un simple pointeur.

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
      char s[10];
    ....
        fgets(s, 10, stdin);
    c'est à cause de char* s; mais je ne vois pas en quoi je mélange
    En C90, les définitions des variables doivent être faites en début de bloc, avant la première instruction du bloc. Ici, char *s est précédé de l'appel à puts
    Publication : Concepts en C

    Mon avatar : Glenn Gould

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

  3. #3
    Nouveau membre du Club
    Profil pro
    Inscrit en
    Novembre 2007
    Messages
    55
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Novembre 2007
    Messages : 55
    Points : 39
    Points
    39
    Par défaut
    Merci j'avais pensé à ça

    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
     
    #include <stdio.h> 
    #include <string.h>
     
    #define STR_SIZE 10
    char s[STR_SIZE];
     
    int main(void)
    {
      puts("Running");
     
      while(1) {
        puts("mydevice> ");
        fgets(s, STR_SIZE, stdin);
     
        if ( strcmp(s,"IDN")==0 ) {
          puts("*IDN? identification \r\n");
        } else {
          puts("Error ! this firmware doesn't understand this command\r\n");
        }
      }
     
      puts("Stopping\r\n"); /* it should never happen */
     
      return 0;
    }
    je n'ai effectivement plus le bus error par contre je ne valide jamais la condition !!!

    Une idée ?

  4. #4
    Expert éminent
    Avatar de Melem
    Homme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Janvier 2006
    Messages
    3 656
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 38
    Localisation : France, Essonne (Île de France)

    Informations professionnelles :
    Activité : Ingénieur développement logiciels
    Secteur : High Tech - Électronique et micro-électronique

    Informations forums :
    Inscription : Janvier 2006
    Messages : 3 656
    Points : 8 389
    Points
    8 389
    Par défaut
    fgets lit aussi le '\n', c'est-à-dire que tu as dans s "IDN\n" et non "IDN". Il y a plusieurs entrées qui traitent de la bonne utilisation de fgets dans la FAQ ...

  5. #5
    Nouveau membre du Club
    Profil pro
    Inscrit en
    Novembre 2007
    Messages
    55
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Novembre 2007
    Messages : 55
    Points : 39
    Points
    39
    Par défaut
    Merci beaucoup

    Voici le code final, j'ai préféré éviter les puts et fgets....

    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
     
    #include <stdio.h> 
    #include <string.h>
    #include <ctype.h>
     
    #define STR_SIZE 10
    char s[STR_SIZE]; /* received string */
    char s2[STR_SIZE]; /* string converted to upper case */
    int i;
     
    int main(void)
    {
      printf("Running\n");
     
      while(1) {
        printf("mydevice> ");
        scanf("%s",s);
        for (i=0 ; i<STR_SIZE ; ++i)
        {
          s2[i]=toupper(s[i]);
        }
        if ( strcmp(s2, "*IDN?")==0 ) {
          printf("*IDN? = device identification\n");
        } else {
          fprintf(stderr,"Error ! this firmware doesn't understand this command\n");
        }
      }
     
      printf("Stopping\n"); /* it should never happen */
     
      return 0;
    }

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

Discussions similaires

  1. bus error bizzare
    Par markotik dans le forum C++
    Réponses: 3
    Dernier message: 20/01/2007, 19h58
  2. Probleme de valeurs fixes et bus error
    Par toto08 dans le forum C
    Réponses: 18
    Dernier message: 02/01/2007, 14h44
  3. [Débutant] Bus Error et scanf
    Par BiLLKiLL dans le forum C
    Réponses: 2
    Dernier message: 17/09/2006, 20h47
  4. bus error sur une machine SUN
    Par mhtrinh dans le forum C
    Réponses: 14
    Dernier message: 10/07/2006, 16h43
  5. bus error
    Par salseropom dans le forum C
    Réponses: 3
    Dernier message: 15/12/2005, 11h59

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