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)
- Erreur 0x80070570 ✓ - Forum Windows 10
- Iptv erreur de lecture - Forum TV & Vidéo
- Erreur s3 bbox - Forum Bbox Bouygues
- Erreur 4101 - Forum Carte graphique
- Erreur de lecture du canal - IPTV - Forum TV & Vidéo
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,