Erreur de segmentation (C)
Axblade28
Messages postés
95
Statut
Membre
-
fiddy Messages postés 441 Date d'inscription Statut Contributeur Dernière intervention -
fiddy Messages postés 441 Date d'inscription Statut Contributeur Dernière intervention -
Bonjour,
Lorsque j'exécute mon programme il s'affiche une erreur de fragmentation. J'aimerais savoir ou se situe l'erreur dans mon code.
Je cherche à stocker dans un tableau un fichier de log afin de pouvoir y récupérer les données voulues.
Merci d'avance.
Lorsque j'exécute mon programme il s'affiche une erreur de fragmentation. J'aimerais savoir ou se situe l'erreur dans mon code.
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
int nombredeligne() {
FILE* fichier = NULL;
int caractereActuel = 0;
int nbrentrees = 0;
char *tableau;
int i = 0;
fichier = fopen("access_log", "r");
if (fichier != NULL) {
caractereActuel = fgetc(fichier);
while (caractereActuel != EOF) {
tableau[i] = caractereActuel;
if (tableau[i] == '\0') {
nbrentrees++; }
i++;
caractereActuel = fgetc(fichier);
}
fclose(fichier);
return nbrentrees;
}
return 0;
}
Je cherche à stocker dans un tableau un fichier de log afin de pouvoir y récupérer les données voulues.
Merci d'avance.
A voir également:
- Erreur de segmentation (C)
- Iptv erreur de lecture - Forum TV & Vidéo
- Erreur 0x80070570 ✓ - Forum Windows 10
- Erreur s3 bbox - Forum Bbox Bouygues
- Erreur de lecture du canal - IPTV - Forum TV & Vidéo
- Erreur 4101 - Forum Carte graphique
8 réponses
Vous n’avez pas trouvé la réponse que vous recherchez ?
Posez votre question
Je pense pas que cela vienne de ça car le programme est pour le moment très simple je viens d'isoler l'unique fonction, je pense que ce n'est pas à cause d'un fichier fragmenté.
Bonjour,
Le problème vient du pointeur.
char *tableau;
tableau[i]=...;
Ce n'est pas bon et cela provoque une erreur de segmentation puisque t'écris dans une zone non allouée.
Il faut que tu réalises l'allocation avec malloc. Par exemple : tableau=malloc(taille);
Ensuite tu pourras écrire dans le tableau.
Ou alors si tu connais la taille à l'avance tu peux faire directement : char tableau[TAILLE];
Cdlt,
Le problème vient du pointeur.
char *tableau;
tableau[i]=...;
Ce n'est pas bon et cela provoque une erreur de segmentation puisque t'écris dans une zone non allouée.
Il faut que tu réalises l'allocation avec malloc. Par exemple : tableau=malloc(taille);
Ensuite tu pourras écrire dans le tableau.
Ou alors si tu connais la taille à l'avance tu peux faire directement : char tableau[TAILLE];
Cdlt,