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 :

Dernier élément qui s'affiche deux fois


Sujet :

C++

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre confirmé
    Profil pro
    Inscrit en
    Septembre 2010
    Messages
    102
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Septembre 2010
    Messages : 102
    Par défaut Dernier élément qui s'affiche deux fois
    Bonjour,

    J'ai créé deux structures que je vais ensuite mettre dans une liste, mais lorsque je fais la lecture du fichier et affiche le contenu de ma structure, la dernière donnée est affichée deux fois. Voici mon code :

    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
    void lireFichierAbonnes(abonne *& listeAbonnes)
    {
    	int compterReservations = 0;
    	ifstream lecture; 
    	abonneFichier personne;
    	reservationFichier reservation;
    	lecture.open("Abonnes.data", ios::binary); 
     
    	if(!lecture.fail())
    	{
    		cout << "Voici la liste des des abonnés : " << endl << endl;
     
     
    		while (!lecture.eof())   // Tant qu'on peut lire un numero d'item      
    		{
    			lecture.read ((char*) &abonne, sizeof(abonneFichier));
     
    			cout << personne.nom << endl;
    			cout << personne.no << endl;
    			cout << personne.adresse << endl;
    			cout << personne.telephone << endl;
    			cout << personne.nbReservations << endl;	
    			while(compterReservations != personne.nbReservations)
    			{
    				lecture.read ((char*) &reservation, sizeof(reservationFichier));
    				cout << reservation.isbn << endl;	
    				cout << reservation.dateReserv.jour << endl;
    				cout << reservation.dateReserv.mois << endl;
    				cout << reservation.dateReserv.an << endl;
    				++ compterReservations;
    			}	
    			compterReservations = 0;	
    		} 
    		lecture.close();
    	}
    	else
    	{
    		cout << "La lecture du fichier n'a pas réussi" << endl;
    	}
    }
    Avez vous une solution?

    Merci d'avance

  2. #2
    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
    Citation Envoyé par Roud9 Voir le message
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    		while (!lecture.eof())   // Tant qu'on peut lire un numero d'item      
    		{
    			lecture.read ((char*) &abonne, sizeof(abonneFichier));
    Déjà, je présume que tu voulais mettre personne et non abonne dans ton read. Ensuite, j'espère que tu es conscient que cette manière de lire est très restrictive. Elle ne marchera pas si ton objet contient des pointeurs sur des sous objets (par exemple des chaînes de caractères), elle ne marchera pas non plus pour relire avec un compilateur des données enregistrées avec un autre (ou le même avec des options de compilation différentes).

    Autrement, ton problème est assez classique, je l'avais deviné à la lecture du titre de ton post, avant d'en lire le contenu. En effet, eof ne devient vrai qu'après que l'on ait essayé de lire trop loin dans le fichier. Donc, tu lis le dernier enregistrement une fois, tu passes dans la boucle à nouveau, tu tentes de faire un nouveau read, celui-ci échoue, mais tu es déjà dans la boucle donc tu continues à créer un enregistrement avec les dernière valeurs lues.

    A remplacer par :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    while (lecture.read ((char*) &abonne, sizeof(abonneFichier)))
    {
     //...
    }
    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.

  3. #3
    Membre confirmé
    Profil pro
    Inscrit en
    Septembre 2010
    Messages
    102
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Septembre 2010
    Messages : 102
    Par défaut
    Merci JolyLoic, cela a résolu mon problème

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

Discussions similaires

  1. Réponses: 23
    Dernier message: 06/05/2010, 23h42
  2. Message d'erreur qui s'affiche deux fois au lieu de trois
    Par popolvictory dans le forum Forms
    Réponses: 2
    Dernier message: 23/10/2008, 16h00
  3. Page qui s'affiche une fois sur deux.
    Par j.b.snecma dans le forum ASP
    Réponses: 1
    Dernier message: 12/11/2007, 20h29
  4. Message de confirm qui s'affiche deux fois
    Par Lolie11 dans le forum Langage
    Réponses: 17
    Dernier message: 07/06/2007, 11h00
  5. Message de confirm qui s'affiche deux fois
    Par Lolie11 dans le forum Général JavaScript
    Réponses: 11
    Dernier message: 05/06/2007, 09h03

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