C++ probleme de flux
Résolu
enee
-
enee -
enee -
Bonjour,
mon projet est fair un t-chat (c quand même plus styler que chat) la partie de lecture et celle d'écriture son déjà crée je fais donc celle de notification mon fichier est modifier par tout les utilisateur.le ficher est encrypter est lisible uniquement sur les t-chat donc vu que on ne peut que rajouter des ligne ou tout supprimer (super utilisateur seulement) donc le ficher ne peut pas changer sans un changement de taille.
mon scripte bug au niveaux de la ligne 31 a 43 mais je ne comprend pas pourquoi l'erreur est que mon ifstream fichier2("C:/nanoc/test.txt");
ne reteste pas la taille du ficher a chaque tour de boucle
voicie mon code
merci d'avance
mon projet est fair un t-chat (c quand même plus styler que chat) la partie de lecture et celle d'écriture son déjà crée je fais donc celle de notification mon fichier est modifier par tout les utilisateur.le ficher est encrypter est lisible uniquement sur les t-chat donc vu que on ne peut que rajouter des ligne ou tout supprimer (super utilisateur seulement) donc le ficher ne peut pas changer sans un changement de taille.
mon scripte bug au niveaux de la ligne 31 a 43 mais je ne comprend pas pourquoi l'erreur est que mon ifstream fichier2("C:/nanoc/test.txt");
ne reteste pas la taille du ficher a chaque tour de boucle
voicie mon code
#include <iostream> #include <fstream> #include <windows.h> using namespace std; int main() { int taille_final; ifstream fichier("C:/nanoc/test.txt"); //On ouvre le fichier fichier.seekg(0, ios::end); //On se déplace à la fin du fichier int taille; taille = fichier.tellg(); //On récupére la position qui correspond donc a la taille du fichier cout << "Taille du fichier au debut: " << taille << " octets." << endl; fichier.close(); string const nomFichier("C:/nanoc/test.txt"); ofstream monFlux(nomFichier.c_str(), ios::app); if(monFlux) { monFlux << "Bonjour, je suis une phrase écrite dans un fichier." << endl; } else { cout << "ERREUR: Impossible d'ouvrir le fichier." << endl; } do { ifstream fichier2("C:/nanoc/test.txt"); //On ouvre le fichier fichier2.seekg(0, ios::end); //On se déplace à la fin du fichier int taille_final; taille_final = fichier2.tellg();//On récupére la position qui correspond donc a la taille du fichier ! cout << "Taille du fichier actuellemet: " << taille << " octets." << endl; std::flush(std::cout); Sleep(1000); }while (taille != taille_final );//on tourne jusque ce soi diferant cout <<"le ficher a ete modifier"<<endl; cout << "le nouveaux message est :"<< endl; return 0; }
merci d'avance
A voir également:
- Nous rencontrons des difficultés pour charger votre flux
- Capture flux - Télécharger - TV & Vidéo
- Impossible de charger les accords de l'utilisateur tv lg - Forum Téléviseurs
- La poste est prête à prendre en charge votre envoi. dès qu'il nous sera confié, vous pourrez suivre son trajet ici ✓ - Forum Consommation & Internet
- Nous rencontrons actuellement des difficultés pour configurer facebook en français - Forum Facebook
- Flux conn: une histoire de fraude - Accueil - Outils
3 réponses
Bonjour,
Pour rappel :
Merci aussi d'attribuer à ton code la couleur syntaxique et la forme correcte avec le bouton
Pour rappel :
Les réponses sont données par des bénévoles, pas par des machines. Il est vivement recommandé d'user des formes minimales de la politesse ("bonjour', "s'il vous plait", "merci d'avance") pour rester dans le cadre de notre charte d'utilisation.
Merci aussi d'attribuer à ton code la couleur syntaxique et la forme correcte avec le bouton
<>
▼.
Bonjour,
Un truc me semble bizarre dans ton code, c'est que tu testes une différence pour ton do while, alors que pour moi tu devrais tester une égalité en affectant au départ à taille_final la valeur de taille.
En plus dans la boucle tu affiches taille, et non taille_final.
Comme ça, à mon avis tu auras un seul tour de boucle, puisque tu écris dans ton fichier juste après avoir calculer sa taille.
Un truc me semble bizarre dans ton code, c'est que tu testes une différence pour ton do while, alors que pour moi tu devrais tester une égalité en affectant au départ à taille_final la valeur de taille.
En plus dans la boucle tu affiches taille, et non taille_final.
#include <iostream> #include <fstream> #include <windows.h> using namespace std; int main() { // int taille_final; ifstream fichier("C:/nanoc/test.txt"); //On ouvre le fichier fichier.seekg(0, ios::end); //On se déplace à la fin du fichier int taille; taille = fichier.tellg(); //On récupére la position qui correspond donc a la taille du fichier cout << "Taille du fichier au debut: " << taille << " octets." << endl; fichier.close(); int taille_final = taille; string const nomFichier("C:/nanoc/test.txt"); ofstream monFlux(nomFichier.c_str(), ios::app); if(monFlux) { monFlux << "Bonjour, je suis une phrase écrite dans un fichier." << endl; } else { cout << "ERREUR: Impossible d'ouvrir le fichier." << endl; } do { ifstream fichier2("C:/nanoc/test.txt"); //On ouvre le fichier fichier2.seekg(0, ios::end); //On se déplace à la fin du fichier // int taille_final; taille_final = fichier2.tellg();//On récupére la position qui correspond donc a la taille du fichier ! cout << "Taille du fichier actuellemet: " << taille_final << " octets." << endl; std::flush(std::cout); Sleep(1000); }while (taille == taille_final );//on tourne jusque ce soi diferant cout <<"le ficher a ete modifier"<<endl; cout << "le nouveaux message est :"<< endl; return 0; }
Comme ça, à mon avis tu auras un seul tour de boucle, puisque tu écris dans ton fichier juste après avoir calculer sa taille.