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 :

Application simple qui pourtant ne marche pas


Sujet :

C

  1. #1
    Membre du Club
    Profil pro
    Inscrit en
    Mars 2004
    Messages
    67
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Mars 2004
    Messages : 67
    Points : 63
    Points
    63
    Par défaut Application simple qui pourtant ne marche pas
    Bonjour a tous.

    Je suis depuis plusieurs heures sur un probleme qui est pourtant tout simple. Je ne vois vraiment pas ou pourait etre le probleme. Bientot je m'arrache les cheveux. Donc si vous pouviez m'eviter la calvitie , j'apprecierai grandement.


    je vous presente mon main.
    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
     
    int main(int argc, char *argv[])
    {
    	char option;
    	char *Nom = (char*)malloc(sizeof(char*));
    	int Num;
    	AnnuR a[MAX];
    	CreateAnnuR("Test",a);
     
    	while(option !='q')
    	{
    		printf("Commande : ");
    		scanf("%c",&option);
    		fflush(stdin);
     
    		if(option == 'i')
    		{
    			printf("Nom \t: \t", Nom);
    			scanf("%s",Nom);
    			fflush(stdin);
    			printf("\nNumero \t: \t", Num);
    			scanf("%d",&Num);
    			fflush(stdin);
    			NewUser(a,Nom,Num);
     
    		}
    		else if(option == 'c')
    		{
    			ConsultingAnnuR(a);
    		}
                    }
    return 0;
    }
    Les fonction utilisé CreateAnnuR, NewUser et ConsultingAnnur sont tres simple.

    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
     
     
    typedef struct AnnuR
    {
    	char *nomAnnu;
    	char *nom;
    	int num;
    	int indexF;
    }AnnuR;
     
    void CreateAnnuR(char *NomAnnu, AnnuR *Annu)
    {	
    	int i;
    	Annu->indexF = 0;
    	printf("Creation de l'annuaire ... %s\n", NomAnnu);
    	for(i=0;i<MAX;i++)
    	{
    		Annu[i].nom = "";
    	}
    }
     
    void ConsultingAnnuR(AnnuR *a)
    {
    	int i =0;
    	while(i<a->indexF)
    	{	
    		printf("Nom \t:\t %s\n", a[i].nom);
    		printf("Numero \t:\t %d\n", a[i].num);
    		printf("======================================\n");
    		i++;
     
    	}
    }
     
    void NewUser(AnnuR *Annu, char *unNom, int unNum)
    {
    	Annu[Annu->indexF].nom = unNom;
    	Annu[Annu->indexF].num = unNum;
    	Annu->indexF ++ ;
    }
    Le probleme de ce programme c'est quand je crée 2 NewUser (ou plus). Le nom des precedent User dans le tableau est remplacé par celui du dernier User crée.


    Si vous pouviez m'aider.

    Merci

  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
    Nom est beaucoup trop petit pour contenir un nom de 20 caractères, ça fonctionne peut-être mais c'est un coup de chance.

    D'autre part, si tu utilises NewUser(AnnuR *Annu, char *unNom, int unNum) dans une boucle pour créer des usagrs, tu risques d' affecter toujours la même adresse au éléments de l'annuaire, donc tu auras toujours le même nom afficher (ce qui se produit apparemment).

    Réfléchis à ce que je viens de dire et poses des questions si besoin est.

    Bon courage.
    "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
    Membre du Club
    Profil pro
    Inscrit en
    Mars 2004
    Messages
    67
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Mars 2004
    Messages : 67
    Points : 63
    Points
    63
    Par défaut
    Merci pour l'info.
    Tu avais raison pour Nom, il etait trop petit, je lui ai donc allouer plus de memoire.

    mais le probleme persiste. J'ai enlever la boucle while (pour faire un test)
    et le probleme persiste.

    j'envoie un petit aperçus du probleme


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

    Informations professionnelles :
    Activité : Retraité

    Informations forums :
    Inscription : Décembre 2003
    Messages : 14 512
    Points : 20 985
    Points
    20 985
    Par défaut Re: Application simple qui pourtant ne marche pas
    Citation Envoyé par ThanosT
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    		scanf("%c",&option);
    		fflush(stdin);
    En plus de ce qui a été dit, j'ajoute que telles quelles, les saisies par scanf() sont fragiles, instables et difficile à écrire correctement. D'autre part, fflush() n'est défini que pour les flux sortants.

    Je conseille ceci :

    http://emmanuel-delahaye.developpez....tes.htm#saisie
    http://emmanuel-delahaye.developpez....s.htm#fichiers
    Pas de Wi-Fi à la maison : CPL

  5. #5
    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
    Il faut allouer de la mémoire à chaque nouvel utilisateur :
    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
    void NewUser(AnnuR *Annu, char *unNom, int unNum)
    {
      char *ptr;
     
      ptr = malloc(strlen(unNom) + 1);
      if (ptr != NULL)
      { 
        strcpy(ptr, unNom);
        Annu[Annu->indexF].nom = ptr;
       }
       else
       {  
          fprintf(stderr, "Pb mémoire\n");
          return;
       }
       Annu[Annu->indexF].num = unNum;
       Annu->indexF ++ ;
    }
    PS il ne faudra pas oublier le libérer la mémoire à la sortie du prog.
    "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

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

    Informations professionnelles :
    Activité : Retraité

    Informations forums :
    Inscription : Décembre 2003
    Messages : 14 512
    Points : 20 985
    Points
    20 985
    Par défaut
    Citation Envoyé par ThanosT
    Tu avais raison pour Nom, il etait trop petit, je lui ai donc allouer plus de memoire.

    mais le probleme persiste. J'ai enlever la boucle while (pour faire un test)
    et le probleme persiste.

    j'envoie un petit aperçus du probleme

    [img ]http://www-iutinfo.unice.fr/~dutratfe/Test/annuR.jpg[/img]
    Non. Pas d'image. Faire un copié collé.

    Dans la structure, il faut stocker une copie de la chaine saisie. Soit en prévoyant de l'espace fixe (tableau de char), soit en attachant un bloc alloué (pointeur, comme tu as fait) avec, par exemple la fonction POSIX.1 'strdup())' (Non standard, mais largement diffusée et facilement reproductible).

    Grilled!
    Pas de Wi-Fi à la maison : CPL

  7. #7
    Membre du Club
    Profil pro
    Inscrit en
    Mars 2004
    Messages
    67
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Mars 2004
    Messages : 67
    Points : 63
    Points
    63
    Par défaut
    Merci les gars vous etes au poil (citation de Monstre et companie).
    Je vous remercie du fond du coeur.
    Vous m'avez sauver ma santé mentale.

    Merci encore

  8. #8
    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 Re: Application simple qui pourtant ne marche pas
    Citation Envoyé par Emmanuel Delahaye
    D'autre part, fflush() n'est défini que pour les flux sortants.
    En effet, et cela peut être un problème pour toi si tu essaies de faire fonctionner le programme autre part que sous Windows (Comportement indéfini).
    Heureusement, avec des fgets(), on n'a pas trop besoin de vider le buffer (moins qu'avec scanf(), en tout cas).

    PS: Emmanuel, tu sais comment on peut vider le buffer en C (ou du moins savoir s'il est vide ou non) ?

    Edit: Oui, j'ai lu tes articles, mais ils n'ont pas répondu à ma question...
    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.

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

    Informations professionnelles :
    Activité : Retraité

    Informations forums :
    Inscription : Décembre 2003
    Messages : 14 512
    Points : 20 985
    Points
    20 985
    Par défaut Re: Application simple qui pourtant ne marche pas
    Citation Envoyé par Médinoc
    Heureusement, avec des fgets(), on n'a pas trop besoin de vider le buffer (moins qu'avec scanf(), en tout cas).

    PS: Emmanuel, tu sais comment on peut vider le buffer en C (ou du moins savoir s'il est vide ou non) ?
    Il suffit d'utiliser les bonnes fonctions de saisies et de les utiliser correctement. Je poste ces liens au moins 3 fois par jour...

    http://emmanuel-delahaye.developpez....tes.htm#saisie
    http://emmanuel-delahaye.developpez....s.htm#fichiers
    Pas de Wi-Fi à la maison : CPL

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

Discussions similaires

  1. Un programme simple qui ne s'éxecute pas
    Par malcolm41000 dans le forum C++
    Réponses: 3
    Dernier message: 01/10/2013, 18h40
  2. [MySQL] Commande Php très simple qui ne s'affiche pas
    Par sabrimi dans le forum PHP & Base de données
    Réponses: 3
    Dernier message: 14/08/2013, 09h58
  3. [WD12] Application client qui ne se lance pas
    Par bruce207 dans le forum WinDev
    Réponses: 5
    Dernier message: 05/06/2009, 02h12
  4. SOS : simple, bête mais ça marche pas
    Par amnay dans le forum Débuter
    Réponses: 3
    Dernier message: 09/02/2009, 17h08
  5. simple Script, mais ca marche pas
    Par super_dz dans le forum Programmation et administration système
    Réponses: 4
    Dernier message: 11/09/2007, 13h00

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