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 :

plusieurs descripteurs pour un même fichier


Sujet :

C

  1. #1
    Membre habitué
    Profil pro
    Inscrit en
    Janvier 2004
    Messages
    136
    Détails du profil
    Informations personnelles :
    Localisation : Belgique

    Informations forums :
    Inscription : Janvier 2004
    Messages : 136
    Points : 133
    Points
    133
    Par défaut plusieurs descripteurs pour un même fichier
    Bonjour,

    peut-on ouvrir le même fichier plusieurs fois en C en lecture (et éventuellement en écriture), positionner les descripteurs à des "offset" différents et faire des opérations de lecture (éventuellement écriture) ?

  2. #2
    Expert éminent sénior

    Avatar de fearyourself
    Homme Profil pro
    Ingénieur Informaticien Senior
    Inscrit en
    Décembre 2005
    Messages
    5 121
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 43
    Localisation : Etats-Unis

    Informations professionnelles :
    Activité : Ingénieur Informaticien Senior
    Secteur : Industrie

    Informations forums :
    Inscription : Décembre 2005
    Messages : 5 121
    Points : 11 877
    Points
    11 877
    Par défaut
    Pour la lecture, ca ne pose pas de probleme, mais pour l'ecriture il y a un probleme de cohesion... C'est generalement deconseille...

    Par exemple:
    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
     
    #include <stdio.h>
     
    int main()
    {
            FILE *f1,*f2;
     
            f1 = fopen("test", "w");
            fprintf(f1,"Hello how are you?");
     
            f2 = fopen("test","w");
            fprintf(f2,"Fine and you?");
     
            fclose(f1);
            fclose(f2);
     
            return 1;
    }
    Montre le probleme, dans test il y a "Fine and you? you?"...

    Jc

  3. #3
    Membre habitué
    Profil pro
    Inscrit en
    Janvier 2004
    Messages
    136
    Détails du profil
    Informations personnelles :
    Localisation : Belgique

    Informations forums :
    Inscription : Janvier 2004
    Messages : 136
    Points : 133
    Points
    133
    Par défaut
    Merci fearyourself,

    Si je connais d'avance la taille de mon fichier et que je prends le soin de toujours positionner mes descripteurs convenablement est-ce que j'ai la garantie d'avoir un résultat cohérent à tous les coups ?

    par exemple : je veux écrire la chaîne "abc" dans le fichier test.

    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
     
    #include <sys/types.h>
    #include <sys/stat.h>
    #include <fcntl.h>
    #include <unistd.h>
    #include <stdlib.h>
     
    int main() {
      int fd, fda, fdb, fdc;
     
      if ((fd = open("test", O_CREAT | O_WRONLY, 00644)) < 0) {
        perror("open ");
        exit(1);
      }
      if (write(fd, "\0\0\0", 3) <= 0) {
        perror("write ");
        exit(1);
      }
     
      fdb = open("test", O_WRONLY);                   // B open
      close(fd);
      fdc = open("test", O_WRONLY);                                    // C open
      lseek(fdb, 1, SEEK_SET);                        // B lseek
      fda = open("test", O_WRONLY);   // A open
      lseek(fdc, 2, SEEK_SET);                                         // C lseek
      write(fdc, "c", 1);                                              // C write
      close(fdc);                                                      // C close
      write(fdb, "b", 1);                             // B write
      write(fda, "a", 1);             // A write
      close(fdb);                                     // B close
      close(fda);                     // A close
     
      exit(0);
    }
    Est ce que le code précédent produira le résultat escompté à tous les coups ? Indépendamment de la quantité de données écrite à chaque posittion.

    NOTE : dans mon exemple j'ai volontairement imbriqué quelque peu les opérations sur les descripteurs. Cependant, le résultat est celui que j'attendais. Je ne positionne pas fda par ce que le caractère 'a' est le premier dans le fichier.

  4. #4
    Expert éminent sénior
    Avatar de Médinoc
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Septembre 2005
    Messages
    27 379
    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 379
    Points : 41 573
    Points
    41 573
    Par défaut
    fearyourself: essaie avec un fflush(f1) avant d'écrire dans f2...

  5. #5
    Modérateur
    Avatar de gangsoleil
    Homme Profil pro
    Manager / Cyber Sécurité
    Inscrit en
    Mai 2004
    Messages
    10 150
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Haute Savoie (Rhône Alpes)

    Informations professionnelles :
    Activité : Manager / Cyber Sécurité

    Informations forums :
    Inscription : Mai 2004
    Messages : 10 150
    Points : 28 121
    Points
    28 121
    Par défaut
    Bonjour,

    Citation Envoyé par sympho
    Si je connais d'avance la taille de mon fichier et que je prends le soin de toujours positionner mes descripteurs convenablement est-ce que j'ai la garantie d'avoir un résultat cohérent à tous les coups ?

    par exemple : je veux écrire la chaîne "abc" dans le fichier test.
    D'abord, pourquoi ne pas utiliser les fonctions standards ? Elles ne te plaisent pas ?

    Ensuite, pour ce qui est d'écrire un unique caractère, tu ne risques pas trop de te créer des problèmes.

    En revanche, dès que tu vas écrire un peu plus, tu riques vite de te retrouver avec des phrases qui vont écraser les précédentes ou les suivantes, et donc de gros problèmes de cohérence.

    Enfin, je ne vois pas l'intéret d'avoir plusieurs descripteurs : un suel descripteur est nécessaire, et tu te déplaces dans ton fichier lorsque tu en as besoin (en sauvegardant la place à laquelle tu viens d'écrire si jamais tu en as besoin).

  6. #6
    Expert éminent sénior

    Avatar de fearyourself
    Homme Profil pro
    Ingénieur Informaticien Senior
    Inscrit en
    Décembre 2005
    Messages
    5 121
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 43
    Localisation : Etats-Unis

    Informations professionnelles :
    Activité : Ingénieur Informaticien Senior
    Secteur : Industrie

    Informations forums :
    Inscription : Décembre 2005
    Messages : 5 121
    Points : 11 877
    Points
    11 877
    Par défaut
    fearyourself: essaie avec un fflush(f1) avant d'écrire dans f2...
    Je suis d'accord, mon code n'était qu'un exemple...

    D'abord, pourquoi ne pas utiliser les fonctions standards ? Elles ne te plaisent pas ?

    Ensuite, pour ce qui est d'écrire un unique caractère, tu ne risques pas trop de te créer des problèmes.

    En revanche, dès que tu vas écrire un peu plus, tu riques vite de te retrouver avec des phrases qui vont écraser les précédentes ou les suivantes, et donc de gros problèmes de cohérence.

    Enfin, je ne vois pas l'intéret d'avoir plusieurs descripteurs : un suel descripteur est nécessaire, et tu te déplaces dans ton fichier lorsque tu en as besoin (en sauvegardant la place à laquelle tu viens d'écrire si jamais tu en as besoin).
    Entièrement d'accord, par contre, j'aurais une tendance à proposer une solution qui utilise un tampon à la place et tu l'écris une fois dans le fichier à la fin quand t'as terminer...

  7. #7
    Membre habitué
    Profil pro
    Inscrit en
    Janvier 2004
    Messages
    136
    Détails du profil
    Informations personnelles :
    Localisation : Belgique

    Informations forums :
    Inscription : Janvier 2004
    Messages : 136
    Points : 133
    Points
    133
    Par défaut
    Bonjour,
    en fait mon code fonctionnne correctement (jusqu'ici), même avec des longues chaînes. Je voulais juste être sur que je n'aurais pas des "surprises". Si quelqu'un aurait un exp. qui ne fonctionne pas je suis prenneur (note: celui de fearyourself ne repositionne pas les descripteurs).
    Quand aux fonctions utilisées, je crois que open est aussi "standard" que fopen non ? Après c'est une histoire de choix

    pour ce qui est du tampon j'y ai pensé, mais vu que la quantité de données à écrire peut être importante ce ne serait pas efficace d'attendre de les avoir toutes avant d'écrire.

    pourquoi plusieurs descripteurs ? Les lectures/écritures pourront se faire en parallèle (fork, pthread) oui je sais c'est affreux ...

    c'est noté pour fopen et open

  8. #8
    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 sympho
    Quand au choix des fonctions, je crois que open est aussi "standard" que fopen non ?
    Non. fopen() fait partie de la définition du langage C. open() n'en fait pas partie. Elle appartient éventuellement à POSIX qui est une norme système et non langage.

    Sauf avis contraire, il n'y a aucune raison d'utiliser open() quand on programme en C.

  9. #9
    Expert éminent sénior

    Avatar de fearyourself
    Homme Profil pro
    Ingénieur Informaticien Senior
    Inscrit en
    Décembre 2005
    Messages
    5 121
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 43
    Localisation : Etats-Unis

    Informations professionnelles :
    Activité : Ingénieur Informaticien Senior
    Secteur : Industrie

    Informations forums :
    Inscription : Décembre 2005
    Messages : 5 121
    Points : 11 877
    Points
    11 877
    Par défaut
    pour ce qui est du tampon j'y ai pensé, mais vu que la quantité de données à écrire peut être importante ce ne serait pas efficace d'attendre de les avoir toutes avant d'écrire.
    Dépendant de la quantité de données qui sont continuellement accédées ou si c'est plutôt juste "de temps en temps", les accès disques seront plus long que juste accédé la RAM. Par contre, tu peux très bien faire un système de gestion de tampon qui met une partie dans des fichiers temporaires en attendant d'avoir la version finale...

    Les lectures/écritures pourront se faire en parallèle (fork, pthread) oui je sais c'est affreux ...
    Si tu as un problème qui comporte des pthreads et des forks, tu vas avoir un problème de cohérence et de synchro assez lourd à mettre en oeuvre (que t'utilises des fichiers ou de la mémoire partagée...) Déjà qu'avec un processus, plusieurs descripteurs d'écriture est une mauvaise chose mais alors avec un programme multi-processus...

Discussions similaires

  1. Plusieurs vues sur un même fichier
    Par minicat dans le forum Eclipse Java
    Réponses: 4
    Dernier message: 05/05/2014, 21h53
  2. Réponses: 5
    Dernier message: 15/03/2007, 11h21
  3. Plusieurs destinations pour un même formulaire
    Par dessinateurttuyen dans le forum Langage
    Réponses: 14
    Dernier message: 01/08/2006, 14h13
  4. Plusieurs valeurs pour un même champ
    Par will89 dans le forum Requêtes
    Réponses: 32
    Dernier message: 14/06/2006, 10h06
  5. Plusieurs vues pour le même objet
    Par nicolas66 dans le forum OpenGL
    Réponses: 4
    Dernier message: 25/10/2004, 10h27

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