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 :

[File] récupérer le contenu d'un fichier


Sujet :

C

  1. #21
    Membre habitué
    Profil pro
    Inscrit en
    Décembre 2004
    Messages
    331
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Décembre 2004
    Messages : 331
    Points : 180
    Points
    180
    Par défaut
    J'ai bien noté le
    malloc peut échouer (comme fopen)
    Comment tester le retour du malloc ?

    ainsi ?

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    content = malloc(size+1);
    if(content !=NULL)
    {
     ..
    }
    Pour les questions concernant le fichier à lire, je ne connais pas la taille ni le contenu à l'avance.

    Il a été aussi question de libérer mon content une fois fini.. mais content est une variable de retour de fonction...

    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
    char * _ReadFile(const char *filename)
    {
    	FILE* fSrc;
    	char buffer[512];
    	int NbLu;
    	char * content=NULL;
    	long size = 0;
     
    	fSrc=fopen(filename, "r");
     
    	if(fSrc != NULL)
    	{
     
     
    		fseek(fSrc, 0, SEEK_END);       // aller en fin 
    		size = ftell(fSrc);             // lire la taille 
    		fseek(fSrc, 0, SEEK_SET); // rétablir la position 
     
    		// alloc
    		content = malloc(size+1);
     
     		while((NbLu=fread(buffer, 1, 512, fSrc)) != 0)
    		{
    			strcat(content, buffer);
    		}
     
    		fclose(fSrc);
    	}
    	content[size+1] = '\0';
     
    	return content;
     
    }
    Dans ce cas, la mémoire ne se libère t-elle pas d'elle même ?

  2. #22
    Membre expert
    Avatar de Pragmateek
    Homme Profil pro
    Formateur expert .Net/C#
    Inscrit en
    Mars 2006
    Messages
    2 635
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 37
    Localisation : France, Val de Marne (Île de France)

    Informations professionnelles :
    Activité : Formateur expert .Net/C#
    Secteur : Conseil

    Informations forums :
    Inscription : Mars 2006
    Messages : 2 635
    Points : 3 958
    Points
    3 958
    Par défaut
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    content = malloc(size+1);
    if(content !=NULL)
    {
     ..
    }
    Plutôt:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    content = malloc(size+1);
    if(content ==NULL)
    {
    /*gestion de l'erreur*/
    }
    Dans ce cas, la mémoire ne se libère t-elle pas d'elle même ?
    Non il faudra faire un "free(content);" quand "content" devient inutile.

  3. #23
    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 kendras
    Comment tester le retour du malloc ? ainsi ?
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    content = malloc(size+1);
    if(content !=NULL)
    {
     ..
    }
    Oui.

    http://emmanuel-delahaye.developpez....tes.htm#malloc
    Il a été aussi question de libérer mon content une fois fini.. mais content est une variable de retour de fonction...

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    char * _ReadFile(const char *filename)
    Identificateur réservé.

    http://emmanuel-delahaye.developpez....htm#id_reserve
    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
     
    {
    	FILE* fSrc;
    	char buffer[512];
    	int NbLu;
    	char * content=NULL;
    	long size = 0;
     
    	fSrc=fopen(filename, "r");
     
    	if(fSrc != NULL)
    	{
     
     
    		fseek(fSrc, 0, SEEK_END);       // aller en fin 
    		size = ftell(fSrc);             // lire la taille 
    		fseek(fSrc, 0, SEEK_SET); // rétablir la position 
     
    		// alloc
    		content = malloc(size+1);
     
     		while((NbLu=fread(buffer, 1, 512, fSrc)) != 0)
    		{
    			strcat(content, buffer);
    		}
     
    		fclose(fSrc);
    	}
    	content[size+1] = '\0';
     
    	return content;
     
    }
    Dans ce cas, la mémoire ne se libère t-elle pas d'elle même ?
    Non.
    Tout ce qui a été alloué doit être libéré.
    Ta méthode de lecture est horrible.
    Tu utilises strcat() sur des tableaux de char qui ne sont pas forcément des chaines valides. Sans compter que c'est totalement inefficace.

    Je ferais comme ça :
    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
     
    <...>
       content = malloc (size + 1);
       if (content != NULL)
       {
          OK = 0;
          if (fread (buffer, 1, size, fSrc) == size)
          {
             buffer[size] = 0;
             OK = 1;
          }
     
          /* traitement de buffer (si OK) */
     
          free (buffer), buffer = NULL;
       }
       fclose(fSrc), fSrc = NULL;
    <...>

  4. #24
    Membre habitué
    Profil pro
    Inscrit en
    Décembre 2004
    Messages
    331
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Décembre 2004
    Messages : 331
    Points : 180
    Points
    180
    Par défaut
    A noter que strcat(content, buffer); ne fonctionne pas lorsque je fais content = malloc(size+1);

    J'ai un Segmentation Fault (core dumped)

    Mon fichier de test contient 578 caractères (espaces compris)

    size = ftell(fSrc);
    size donne 606

    Après recherche, pour que mon strcat fonctionne, il faudrait que je fasse un malloc à 1017 au moins
    content = malloc(1017);
    Pourquoi ?

  5. #25
    Membre habitué
    Profil pro
    Inscrit en
    Décembre 2004
    Messages
    331
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Décembre 2004
    Messages : 331
    Points : 180
    Points
    180
    Par défaut
    Ok!
    Oublions mon message précédent suite à la réponse Emmanuel .

    Merci, je vais tester ça de suite

  6. #26
    Membre habitué
    Profil pro
    Inscrit en
    Décembre 2004
    Messages
    331
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Décembre 2004
    Messages : 331
    Points : 180
    Points
    180
    Par défaut
    Ok, donc cela me donne ça :

    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
    char * pReadFile(const char *filename)
    {
    	FILE* fSrc;
    	char buffer[10000];
    	int NbLu;
    	char * content=NULL;
    	long unsigned size = 0;
    	int OK = 0;
    	fSrc=fopen(filename, "r");
     
    	if(fSrc != NULL)
    	{
    		fseek(fSrc, 0, SEEK_END);       // aller en fin 
    		size = ftell(fSrc);             // lire la taille 
    		fseek(fSrc, 0, SEEK_SET); 			// rétablir la position 
     
    		if (fread (buffer, 1, size, fSrc) == size)
    		{
    			buffer[size] = 0;
    			OK = 1;
    		}
     
    		/* traitement de buffer (si OK) */
    		if(OK==1)
    		{
    			content = malloc(sizeof(buffer) + 1);
    			strcpy(content, (char*)buffer);
    		}
     
    		free (buffer);
     
    		fclose(fSrc), fSrc = NULL;
    	}
    	return content;
     
    }
    C'est surement plus joli et plus propre ainsi.
    Merci pour les corrections de syntaxe que je ne maitrise pas forcément (voir pas du tout).

    Comment puis-je libérer content ?

  7. #27
    Membre éprouvé Avatar de gnto
    Homme Profil pro
    Ingénieur système logiciel
    Inscrit en
    Janvier 2006
    Messages
    923
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 40
    Localisation : France, Gironde (Aquitaine)

    Informations professionnelles :
    Activité : Ingénieur système logiciel
    Secteur : Aéronautique - Marine - Espace - Armement

    Informations forums :
    Inscription : Janvier 2006
    Messages : 923
    Points : 1 210
    Points
    1 210
    Par défaut
    Citation Envoyé par kendras
    Comment puis-je libérer content ?
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    char * pVar;
     
    pVar = pReadFile("toto.txt");
     
    free(pVar);

  8. #28
    Membre habitué
    Profil pro
    Inscrit en
    Décembre 2004
    Messages
    331
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Décembre 2004
    Messages : 331
    Points : 180
    Points
    180
    Par défaut
    Ok.

    Concernant cette libération de mémoire, ceci est uniquement valable lorsque l'on alloue de la mémoire avec malloc ?

    J'ai par exemple crée une structure "transmission".
    Est-il necessaire/possible de nettoyer les variables de type "transmission" ?

  9. #29
    Membre éprouvé Avatar de gnto
    Homme Profil pro
    Ingénieur système logiciel
    Inscrit en
    Janvier 2006
    Messages
    923
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 40
    Localisation : France, Gironde (Aquitaine)

    Informations professionnelles :
    Activité : Ingénieur système logiciel
    Secteur : Aéronautique - Marine - Espace - Armement

    Informations forums :
    Inscription : Janvier 2006
    Messages : 923
    Points : 1 210
    Points
    1 210
    Par défaut
    ben la faut aller voir des tutos ou ouvrir un bouquin sur le C sur les déclarations statiques et dynamiques

  10. #30
    Membre habitué
    Profil pro
    Inscrit en
    Décembre 2004
    Messages
    331
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Décembre 2004
    Messages : 331
    Points : 180
    Points
    180
    Par défaut
    OK, merci pour se renvoie vers la documentation ;-)

  11. #31
    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 kendras
    Ok, donc cela me donne ça :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    char * pReadFile(const char *filename)
    {
    	char buffer[10000];
    <...>
    		free (buffer);
    }
    Je n'ai jamais dit qu'il fallait que buffer soit un tableau de taille fixe. au contraire :

    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
    41
    42
    43
    44
    45
    46
    47
    48
    49
    50
    51
    52
    53
    54
    55
    56
     
    #include <stdio.h>
    #include <stdlib.h>
     
    static char *pReadFile(const char *filename)
    {
       char *buffer = NULL;
       FILE *fSrc = fopen(filename, "r");
     
       if (fSrc != NULL)
       {
          fseek(fSrc, 0, SEEK_END);       // aller en fin
          {
             unsigned long size = ftell(fSrc);             // lire la taille
             /* ne pas depasser ce que peut contenir un size_t ... */
             if (size < (size_t) - 1)
             {
                rewind(fSrc);    // rétablir la position
     
                /* allouer le bloc + une place pour le 0 */
                buffer = malloc(size + 1);
                if (buffer != NULL)
                {
                   int ok = 0;
                   /* lire le ficher (in one gulp...) */
                   if (fread (buffer, 1, size, fSrc) == size)
                   {
                      /* ajouter le 0 final */
                      buffer[size] = 0;
                      ok = 1;
                   }
                   if (!ok)
                   {
                      /* en cas d'erreur de lecture, liberer le bloc ... */
                      free (buffer), buffer = NULL;
                   }
                }
             }
          }
          fclose(fSrc), fSrc = NULL;
       }
       return buffer;
    }
     
    int main()
    {
       char * s = pReadFile("corbeau.txt");
     
       if (s != NULL)
       {
          puts (s);
          free (s), s = NULL;
       }
     
       return 0;
    }

  12. #32
    Membre habitué
    Profil pro
    Inscrit en
    Décembre 2004
    Messages
    331
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Décembre 2004
    Messages : 331
    Points : 180
    Points
    180
    Par défaut
    Oui, merci.
    J'avais corrigé entre temps en me rendant compte que c'était débile de mettre du statique

+ Répondre à la discussion
Cette discussion est résolue.
Page 2 sur 2 PremièrePremière 12

Discussions similaires

  1. Réponses: 10
    Dernier message: 10/02/2007, 18h44
  2. Réponses: 5
    Dernier message: 10/04/2006, 12h07
  3. Aide : Décoder, récupérer le contenu d'un fichier .pst
    Par ATTIA dans le forum API, COM et SDKs
    Réponses: 10
    Dernier message: 23/03/2006, 16h11
  4. Comment récupérer le contenu de plusieurs fichiers textes ?
    Par calimero2611 dans le forum Langage
    Réponses: 9
    Dernier message: 19/02/2006, 15h45
  5. [ethereal] récupérer le contenu d'un fichier envoyé ?
    Par in dans le forum Développement
    Réponses: 1
    Dernier message: 19/06/2005, 15h44

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