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 :

Memory Fault


Sujet :

C

  1. #21
    Nouveau membre du Club
    Inscrit en
    Novembre 2003
    Messages
    166
    Détails du profil
    Informations forums :
    Inscription : Novembre 2003
    Messages : 166
    Points : 39
    Points
    39
    Par défaut Memory Fault
    je sais qu'elle est faisable par
    strftime (date1,29,"%m/%d/%Y %T", gmtime (&sbuf.st_mtime));

    tu m'a dit que si possible de retirer les '\n' ds ctime(), je sais pas comment!!

    Merci de ton Aide

  2. #22
    Rédacteur/Modérateur
    Avatar de Trap D
    Profil pro
    Inscrit en
    Septembre 2003
    Messages
    4 942
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Septembre 2003
    Messages : 4 942
    Points : 6 498
    Points
    6 498
    Par défaut
    Tu les pistes en faisant un
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    p = strchr(machaine, '\n');
    if (p != NULL)
    // le '\n' a été trouvé
      *p = 0;
    // on l'enlève !
    "La haine seule fait des choix" - Koan Zen
    "Il ne faut pas être meilleur que les autres, il faut être meilleur que soi." Albert Jacquard
    "Ceux qui savent où ils ont posé leur parapluie ne sont pas alcooliques." - pgibonne.
    Faites du Prolog, ça vous changera les idées !
    Ma page Prolog
    Mes codes sources commentés

    Mon avatar : La Madeleine à la veilleuse de Georges de La Tour

  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 Trap D
    Tu les pistes en faisant un
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    p = strchr(machaine, '\n');
    if (p != NULL)
    // le '\n' a été trouvé
      *p = 0;
    // on l'enlève !
    Mais dans le cas du ctime(), ça ne marchera qu'avec une copie de la chaine. C'est tellement compliqué qu'il vaut mieux utiliser strftime().
    Pas de Wi-Fi à la maison : CPL

  4. #24
    Nouveau membre du Club
    Inscrit en
    Novembre 2003
    Messages
    166
    Détails du profil
    Informations forums :
    Inscription : Novembre 2003
    Messages : 166
    Points : 39
    Points
    39
    Par défaut Memory Fault
    bonjour
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
     
     
     
         	char string[40];
            mode=sbuf.st_mode;
            size=sbuf.st_size;
            patch=argv[i];
            char * pt = "sbuf.st_size";
            strcpy(string, pt); 
            printf("%s\n", string);
     
            return 0;
            exit (1);
    j'arrive pas à copier le contenu de sbuf.st_size ds string

    Merci

  5. #25
    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 Re: Memory Fault
    Citation Envoyé par melmouj
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
     
         	char string[40];
            mode=sbuf.st_mode;
            size=sbuf.st_size;
            char * pt = "sbuf.st_size";
            strcpy(string, pt); 
            printf("%s\n", string);
    j'arrive pas à copier le contenu de sbuf.st_size ds string
    Le contenu de sbuf.st_size est probablement un entier. Il faut utiliser sprintf(), le formatteur et le cast qui vont bien pour en faire une représentation textuelle (en décimal, par exemple).
    Pas de Wi-Fi à la maison : CPL

  6. #26
    Nouveau membre du Club
    Inscrit en
    Novembre 2003
    Messages
    166
    Détails du profil
    Informations forums :
    Inscription : Novembre 2003
    Messages : 166
    Points : 39
    Points
    39
    Par défaut Memory fault
    voila la suite
    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
    57
    58
     
    #include <sys/types.h>
    #include <sys/stat.h>
    #include <stdio.h>
    #include <stdlib.h>
    #include <time.h>
    #include <string.h>
     
    int tri(const void *,const void *);
    int main (int argc, char *argv[])
    {
      int i, mode;
      int size;
      int result;
      char * patch=NULL;
      char date1[30];
      char date2[30];
      char date3[30];
      struct stat sbuf;
     
      for(i=1; i < argc; i++)
      {
         result=stat(argv[i], &sbuf);
         if(result == 0)
         {
            mode=sbuf.st_mode;
            size=sbuf.st_size;
            char string[40];
            char * pt = "sbuf.st_size";
            //sprintf(string,"%d", (int *)sbuf.st_size);
            //printf("%s\n", string);
     
          //  strftime (date1,29,"%m/%d/%Y %T", gmtime (&sbuf.st_mtime));
           // strftime (date2,29,"%m/%d/%Y %T", gmtime (&sbuf.st_atime));
           // strftime (date2,29,"%m/%d/%Y %T", gmtime (&sbuf.st_atime));
           // patch=argv[i];
            //if(S_ISDIR (mode)) {
              //printf ("%12d %s %s %s\n",sbuf.st_size,date1,date2,date3,patch);
            //}
     
            //if(S_ISLNK (mode)) printf("%s S File size %ld\n", argv[i],
            //if(S_ISREG (mode)) {
              //printf("%12d %s %s %s\n",sbuf.st_size,date1,date2,date3,patch);
            //}
            sprintf(string,"%d", (int *)sbuf.st_size);
            qsort((void*)string,40,sizeof(string),tri);
            printf("%s\n", string);
         }
            else
              printf("Problem getting information\n");
      }
      return 0;
    }
     
     
    int tri(const void * a, const void * b) {
      return(strcmp(*(int *)a,*(int *)b));
    }
    ça me donne:
    cc -c conversion.c
    conversion.c: Dans la fonction « tri »:
    conversion.c:62: attention : passage de l'argument n°1 de « strcmp » transforme un entier en pointeur sans transtypage
    conversion.c:62: attention : passage de l'argument n°2 de « strcmp » transforme un entier en pointeur sans transtypage

    par contre ds ce cas return(strcmp(*(char **)a,*(char **)b));
    ça fonctionne sasn erreur.

    Merci de m'aider

  7. #27
    Expert éminent sénior
    Avatar de Médinoc
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Septembre 2005
    Messages
    27 369
    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 369
    Points : 41 519
    Points
    41 519
    Par défaut
    ben... strcmp((const char *)a, (const char *)b) ne suffit-il pas?
    SVP, pas de questions techniques par MP. Surtout si je ne vous ai jamais parlé avant.

    "Aw, come on, who would be so stupid as to insert a cast to make an error go away without actually fixing the error?"
    Apparently everyone.
    -- Raymond Chen.
    Traduction obligatoire: "Oh, voyons, qui serait assez stupide pour mettre un cast pour faire disparaitre un message d'erreur sans vraiment corriger l'erreur?" - Apparemment, tout le monde. -- Raymond Chen.

  8. #28
    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 Re: Memory fault
    Citation Envoyé par melmouj
    voila la suite
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
     
    <...>
       for(i=1; i < argc; i++)
      {
         result=stat(argv[i], &sbuf);
    <...>
            qsort((void*)string,40,sizeof(string),tri);
      }
    Il faut commencer par écrire un algorithme qui tient la route...

    Pour utiliser qsort(), il faut un tableau. Il faut constituer ce tableau en lisant chaque élément du repertoire (l'agrandir si nécessaire).
    Ensuite, on trie le tableau selon le critère choisi (implémenté dans la fonction de comparaison curieusement appelée 'tri' ici...)

    Je conseille un tableau de 'struct stat'.

    Ensuite, on verra les problèmes de syntaxe...
    Pas de Wi-Fi à la maison : CPL

  9. #29
    Nouveau membre du Club
    Inscrit en
    Novembre 2003
    Messages
    166
    Détails du profil
    Informations forums :
    Inscription : Novembre 2003
    Messages : 166
    Points : 39
    Points
    39
    Par défaut Memory Fault
    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
     
    struct stat sbuf;
      char tab[100];
     
    for(i=1; i < argc; i++) 
      { 
     
    .
    .
    .
    .
    sprintf(tab,"%d", (int *)sbuf.st_size); 
            printf("%s\n", tab); 
            for(j=1;j<argc;j++) {              
              qsort((void*)tab,32,sizeof(tab),tri); 
            } 
     
    } 
     
    int tri(const void * a, const void * b) { 
     return (strcmp(*(char **)a, *(char **)b)); 
    }

  10. #30
    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 Re: Memory Fault
    Citation Envoyé par melmouj
    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
     
    struct stat sbuf;
      char tab[100];
     
    for(i=1; i < argc; i++) 
      { 
    sprintf(tab,"%d", (int *)sbuf.st_size); 
            printf("%s\n", tab); 
            for(j=1;j<argc;j++) {              
              qsort((void*)tab,32,sizeof(tab),tri); 
            } 
     
    } 
     
    int tri(const void * a, const void * b) { 
     return (strcmp(*(char **)a, *(char **)b)); 
    }
    Tu veux trier des caractères ? Qu'est-ce que tu ne comprends pas dans les réponses précédentes ?
    Pas de Wi-Fi à la maison : CPL

  11. #31
    Nouveau membre du Club
    Inscrit en
    Novembre 2003
    Messages
    166
    Détails du profil
    Informations forums :
    Inscription : Novembre 2003
    Messages : 166
    Points : 39
    Points
    39
    Par défaut Memory Fault
    ça marche pas qd je fait
    return (strcmp(*(int *)a, *(int *)b));

  12. #32
    Nouveau membre du Club
    Inscrit en
    Novembre 2003
    Messages
    166
    Détails du profil
    Informations forums :
    Inscription : Novembre 2003
    Messages : 166
    Points : 39
    Points
    39
    Par défaut Memory Fault
    j'ai essayé comme ça mais encore des erreurs

    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
     
    struct stat sbuf;
      char T[100];
     
      for(i=1; i < argc; i++) 
      { 
         result=stat(argv[i], &sbuf); 
         if(result == 0) 
         { 
            mode=sbuf.st_mode; 
            size=sbuf.st_size; 
            sprintf(T,"%d", (int *)sbuf.st_size); 
            printf("%s\n", T); 
            puts(T);
     
     
            qsort((int *)T,argc,sizeof(int),compar); 
     
     
    } 
            else 
              printf("Problem getting information\n"); 
      } 
      return 0; 
    } 
     
    int compar(const void *a, const void *b) { 
      if(*(int *)a<(*(int *)b) return (*(int *)a);
     
      return 0;
    }

  13. #33
    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 Re: Memory Fault
    Citation Envoyé par melmouj
    j'ai essayé comme ça mais encore des erreurs
    Il faut cesser de programmer au hasard. Quels sont les mots que tu ne comprends pas dans :
    Pour utiliser qsort(), il faut un tableau. Il faut constituer ce tableau en lisant chaque élément du repertoire (l'agrandir si nécessaire).
    Ensuite, on trie le tableau selon le critère choisi (implémenté dans la fonction de comparaison curieusement appelée 'tri' ici...)

    Je conseille un tableau de 'struct stat'.
    Pas de Wi-Fi à la maison : CPL

  14. #34
    Nouveau membre du Club
    Inscrit en
    Novembre 2003
    Messages
    166
    Détails du profil
    Informations forums :
    Inscription : Novembre 2003
    Messages : 166
    Points : 39
    Points
    39
    Par défaut Memory Fault
    ça: un tableau de 'struct stat'.

  15. #35
    Nouveau membre du Club
    Inscrit en
    Novembre 2003
    Messages
    166
    Détails du profil
    Informations forums :
    Inscription : Novembre 2003
    Messages : 166
    Points : 39
    Points
    39
    Par défaut Memory Fault
    char T[100]; est un tableau,

    on copie dedons sprintf(T,"%d", (int *)sbuf.st_size);

  16. #36
    Nouveau membre du Club
    Inscrit en
    Novembre 2003
    Messages
    166
    Détails du profil
    Informations forums :
    Inscription : Novembre 2003
    Messages : 166
    Points : 39
    Points
    39
    Par défaut Memory Fault
    tu veut dire :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
     
    struct stat {
      	char T[100];
      };	
     
      struct stat sbuf;

  17. #37
    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 Re: Memory Fault
    Citation Envoyé par melmouj
    tu veut dire :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
     
    struct stat {
      	char T[100];
      };	
     
      struct stat sbuf;
    Non.
    Pas de Wi-Fi à la maison : CPL

  18. #38
    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 Re: Memory Fault
    Citation Envoyé par melmouj
    ça: un tableau de 'struct stat'.
    Et bien il suffit de demander au lieu de bricoler.

    Tu sais faire un tableau d'int :
    plus généralement un tableau de type T
    Ici, on veut un tableau de 'struct stat'. Donc :
    tout simplement (tailles arbitraires).

    Rappel : struct stat est défini dans <sys/stat.h>
    Pas de Wi-Fi à la maison : CPL

  19. #39
    Nouveau membre du Club
    Inscrit en
    Novembre 2003
    Messages
    166
    Détails du profil
    Informations forums :
    Inscription : Novembre 2003
    Messages : 166
    Points : 39
    Points
    39
    Par défaut Memory fault
    Merci de ton aide emmanuel,
    voila ce que j'ai fait, je suis bloqué.
    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
     
    struct stat sbuf[argc];
      char T[50];
      for(i=1; i < argc; i++)
      {
         result=stat(argv[i], &sbuf[i]);
         if(result == 0)
         {
            mode=sbuf[i].st_mode;
            size=sbuf[i].st_size;
            sprintf(T,"%d", (int *)sbuf[i].st_size);
            printf("%s\n", T);
          //  qsort((int *)sbuf[i].st_size), 20, sizeof((int *)sbuf[0].st_size)),tri);
            .........................
    }
     
     
    // int tri(const void * a, const void * b) {
      //return((*(int *)a - *(int *)b);
    //}
    tu m'a dis il faut copie sbuf[i].st_size ds un tableau.

    je l'ai deja fait printf("%s\n", T); il donne:
    1118
    1044782
    48
    10997
    1481
    1312
    456
    80
    204
    80
    48
    1243
    1968
    491
    267
    80
    214
    12201
    72
    158
    par contre qsort ne marche pas.

  20. #40
    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 Re: Memory fault
    Citation Envoyé par melmouj
    Merci de ton aide emmanuel,
    voila ce que j'ai fait, je suis bloqué.
    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
     
    struct stat sbuf[argc];
      char T[50];
      for(i=1; i < argc; i++)
      {
         result=stat(argv[i], &sbuf[i]);
         if(result == 0)
         {
            mode=sbuf[i].st_mode;
            size=sbuf[i].st_size;
            sprintf(T,"%d", (int *)sbuf[i].st_size);
            printf("%s\n", T);
          //  qsort((int *)sbuf[i].st_size), 20, sizeof((int *)sbuf[0].st_size)),tri);
            .........................
    }
     
     
    // int tri(const void * a, const void * b) {
      //return((*(int *)a - *(int *)b);
    //}
    tu m'a dis il faut copie sbuf[i].st_size ds un tableau.
    NON! J'ai dit de constituer un tableau de struct stat (ce que tu as fait, d'ailleurs). Il suffit maintenant de recopier chaque struct stat mise a jour par stat() dans le tableau...
    En fait, tu fais tout en une opération avec ceci :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
         result=stat(argv[i], &sbuf[i]);
    ce qui es correct.
    je l'ai deja fait printf("%s\n", T); il donne:
    1118
    1044782
    48
    10997
    1481
    1312
    456
    80
    204
    80
    48
    1243
    1968
    491
    267
    80
    214
    12201
    72
    158
    par contre qsort ne marche pas.
    Relis mon texte. J'ai dit qu'il fallait d'abord constituer le tableau de struct stat, et ensuite (donc hors de la boucle), il faut appeler qsort() pour faire le tri sur des élements du tableau (qui sont évidemment des struct stat).

    En fait, tu ne devrais pas aborder un thème tant que ne maîtrise pas le précédent. Savoir utiliser qsort(), c'est tout un art, et si en même temps tu patauge dans les struct stat, tu ne vas pas y arriver. Il faut faire une chose à la fois. Commence par apprendre à utiliser qsort() avec
    • des entiers
    • des chaines
    • des structure (en choisissant un champ de tri particulier).

    En ayant en tête que ce sui est passé à la fonction de comparaison, ce sont 2 adresses d'éléments du tableau. Elles arrivent de façon anonyme (void const *), et pour les utiliser il faut probablement 2 pointeurs locaux du bon type...
    Pas de Wi-Fi à la maison : CPL

Discussions similaires

  1. Problème de Core dumped, Memory Fault
    Par pmboutteau dans le forum C
    Réponses: 26
    Dernier message: 26/03/2009, 16h07
  2. [Mémoire] Probleme de Memory Fault louche
    Par wawa84 dans le forum C++
    Réponses: 1
    Dernier message: 23/11/2008, 20h53
  3. Memory fault à l'exécution
    Par miketidy dans le forum C++
    Réponses: 26
    Dernier message: 09/09/2008, 14h43
  4. Memory fault avec une structure
    Par Neuromancien2 dans le forum C
    Réponses: 4
    Dernier message: 04/01/2008, 14h25
  5. Memory fault(coredump)
    Par nono1 dans le forum C
    Réponses: 8
    Dernier message: 17/12/2002, 17h26

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