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 :

[Fichier] Rapidité d'ecriture


Sujet :

C++

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre éclairé Avatar de ZaaN
    Inscrit en
    Novembre 2005
    Messages
    819
    Détails du profil
    Informations forums :
    Inscription : Novembre 2005
    Messages : 819
    Par défaut [Fichier] Rapidité d'ecriture
    Hello,

    Au lieu de faire:

    File open
    File write
    File write
    File write
    File close

    y a ti plus performant et plus rapide ? (passer par un object intermediaire ) buffer, stream ?

  2. #2
    Membre confirmé
    Profil pro
    Inscrit en
    Mars 2006
    Messages
    80
    Détails du profil
    Informations personnelles :
    Âge : 42
    Localisation : France, Territoire de Belfort (Franche Comté)

    Informations forums :
    Inscription : Mars 2006
    Messages : 80
    Par défaut
    Citation Envoyé par ZaaN
    Hello,

    Au lieu de faire:

    File open
    File write
    File write
    File write
    File close

    y a ti plus performant et plus rapide ? (passer par un object intermediaire ) buffer, stream ?
    Moi en C++ pour faire des écritures lectures de fichier,j'utilise les ofsteram,
    un exemple de code :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
     
      ofstream file;
      file.open("fichier.txt", ios::out | ios::app);
      file  << "Ecriture ....." <<endl;
      file.close();
    un lien pour avoir les differents modes d'ouverture :http://www.cplusplus.com/reference/i...ream/open.html
    J'espére que j'ai répondu à ta question

  3. #3
    Membre éclairé Avatar de ZaaN
    Inscrit en
    Novembre 2005
    Messages
    819
    Détails du profil
    Informations forums :
    Inscription : Novembre 2005
    Messages : 819
    Par défaut
    c'est aussi ce que j ai decris et utilisé mais sans le preciser...

    la methode write est elle plus lente que l'operateur << sur les ofstream ?

  4. #4
    Membre confirmé
    Profil pro
    Inscrit en
    Mars 2006
    Messages
    80
    Détails du profil
    Informations personnelles :
    Âge : 42
    Localisation : France, Territoire de Belfort (Franche Comté)

    Informations forums :
    Inscription : Mars 2006
    Messages : 80
    Par défaut
    Citation Envoyé par ZaaN
    c'est aussi ce que j ai decris et utilisé mais sans le preciser...

    la methode write est elle plus lente que l'operateur << sur les ofstream ?
    je croyais que tu voulais effectué une ouverture , écriture et fermeture de fichier avec un minimum de ligne de code .
    Question rapidité je peu rien te dire -_-.
    Une idée , independante de la méthode que tu va utiliser pour ta gestion de fichiers si t'a plein de fichiers à traiter en méme temps, est d'utiliser le multithreading comme ca tu pourra lancer plein de traitements en paralléles et l'execution de ton code sera plus rapide.

  5. #5
    Membre chevronné
    Profil pro
    Inscrit en
    Avril 2007
    Messages
    366
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Avril 2007
    Messages : 366
    Par défaut
    a priori, l utilisation de << dans iostream n'apportera pas grand chose (ni ne retirera) a une lecture plus standard. A un moment ou un autre, << implique une lecture de toute facon...

    En revanche, la ou tu peux peut etre joue, c'est sur les appels de lecture ...

    FILE * f = fopen(...);

    int f = open(...);

    Il s agit de deux API "distinctes". La premiere utilise un tampon interne pour eviter de multiples petites lectures / ecrtiture (consommatrices en temps) . La seconde lit exactement les octets qu on lui demande, rien de plus donc :

    Pour "optimiser" un acces disque mieux vaut ton lire d'un coup (si c est possible bien sur), car on evite la mutliplication des appels systemes (bloquant) et donc les context switching (couteux)

    En cas d 'appels lecture/ecriture multiples , il faut mieux bufferiser tout ca et donc utiliser l'aPI (fread / fwrite) (en fait mieux vaut TOUJOURS l utiliser)

  6. #6
    Expert éminent
    Avatar de koala01
    Homme Profil pro
    aucun
    Inscrit en
    Octobre 2004
    Messages
    11 644
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 53
    Localisation : Belgique

    Informations professionnelles :
    Activité : aucun

    Informations forums :
    Inscription : Octobre 2004
    Messages : 11 644
    Par défaut
    salut,
    Citation Envoyé par stranger
    Moi en C++ pour faire des écritures lectures de fichier,j'utilise les ofsteram,
    un exemple de code :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
     
      ofstream file;
      file.open("fichier.txt", ios::out | ios::app);
      file  << "Ecriture ....." <<endl;
      file.close();
    un lien pour avoir les differents modes d'ouverture :http://www.cplusplus.com/reference/i...ream/open.html
    J'espére que j'ai répondu à ta question
    Personnellement, je ferais meme plutot un truc du genre de
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
     
    ofstream file("fichier.txt",ios::app);
    if(!file.is_open())
        throw runtime_error("acces en ecriture au fichier impossible");
    file<< "ecriture..."<<endl;
    En effet, le flux (ici le fichier) est d'office ouvert si le constructeur dispose des informations qui lui sont nécessaires...

    La levée d'une exception est mis "pour mémoire" (pas *forcément* obligatoire, et à gérer ailleurs ) et a pour but de pallier une éventuelle inaccessiblité du fichier (bloqué par une autre application )

    Le fichier étant d'office fermé lorsque la fonction est quittée du fait que le flux est détruit à la fin de la fonction, il n'est pas non plus nécessaire de le fermer explicitement

    Ceci dit, pour répondre à la question originelle, il est clair qu'il est préférable, d'un stricte point de vue des performances, d' ouvrir le fichier une seule fois et d'y "balancer" l'ensemble des données à écrire dedans, plutot que de l'ouvrir une multitude de fois pour n'y écrire que quelques mots

    L'utilisation des *fstream permet, en outre, de travailler de manière plus sécurisante que le FILE* et son florilege de fonctions associées, mais ne modifie en rien les temps d'acces et de lecture
    A méditer: La solution la plus simple est toujours la moins compliquée
    Ce qui se conçoit bien s'énonce clairement, et les mots pour le dire vous viennent aisément. Nicolas Boileau
    Compiler Gcc sous windows avec MinGW
    Coder efficacement en C++ : dans les bacs le 17 février 2014
    mon tout nouveau blog

  7. #7
    Membre chevronné
    Profil pro
    Inscrit en
    Avril 2007
    Messages
    366
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Avril 2007
    Messages : 366
    Par défaut
    Citation Envoyé par koala01
    L'utilisation des *fstream permet, en outre, de travailler de manière plus sécurisante que le FILE* et son florilege de fonctions associées, mais ne modifie en rien les temps d'acces et de lecture
    absolument d accord

  8. #8
    Membre confirmé
    Profil pro
    Inscrit en
    Mars 2006
    Messages
    80
    Détails du profil
    Informations personnelles :
    Âge : 42
    Localisation : France, Territoire de Belfort (Franche Comté)

    Informations forums :
    Inscription : Mars 2006
    Messages : 80
    Par défaut
    Merci koala pour tes explications tu m'a apporté plein d'info. que je ne savais pas (ou que j'ai oublier de traiter comme les exceptions que je vais de suite gérer dans un frame work que je developpe en ce moment )

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

Discussions similaires

  1. ouvrir un fichier en lecture/ecriture
    Par imsse dans le forum VBScript
    Réponses: 3
    Dernier message: 27/01/2010, 15h01
  2. Export de fichier en ascii : ecriture scientifique
    Par Baelros dans le forum MATLAB
    Réponses: 1
    Dernier message: 07/03/2008, 19h45
  3. Fichier en lecture / ecriture
    Par titan_33 dans le forum C#
    Réponses: 4
    Dernier message: 21/05/2007, 13h51
  4. peut-on proteger un fichier xml en ecriture?
    Par link256 dans le forum XML/XSL et SOAP
    Réponses: 2
    Dernier message: 25/05/2006, 12h43
  5. [fichier binaire]lecture ecriture dump
    Par parsy dans le forum Langage
    Réponses: 7
    Dernier message: 10/08/2005, 18h40

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