В настоящее время мы работаем над проектом, где нам нужно работать над некоторым текстом, для этого нам нужно разделить текст на более мелкие разделы.Проблемы с malloc вызывают ошибку сегментации
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
typedef struct paragraph{
char **words;
}paragraph;
typedef struct text{
char name[100];
paragraph *list;
}text;
void readFileContent(FILE *file, paragraph *pa, int size){
char localString[100];
pa->words = (char **)malloc(size * sizeof(char *));
int i = 0, z;
while(fscanf(file, "%s", localString) == 1 && i < size){
z = strlen(localString);
pa->words[i] = (char *)malloc(z + 1);
strcpy(pa->words[i], localString);
i++;
}
}
void main(){
int i = 0, n, z;
FILE *file;
text *localText;
localText = (text *)malloc(sizeof(text));
openFile(&file, "test.txt");
i = countWords(file);
i = i/50 + 1; // calculate the number of section need for the text
localText->list = calloc(sizeof(paragraph *), i);
for(n = 0; n < i ; n++){
printf("Paragraph - %d\n", n);
readFileContent(file, &localText->list[i], 50);
}
for(n = 0; n < i ; n++){
printf("Paragraph - %d", n);
for(z = 0; z < 50; z++){
printf("no. %d\n", z);
printf("%s\n", localText->list[n].words[z]);
}
}
}
Когда я пытаюсь запустить программу, я получаю ошибку сегментации в контуре печати внизу. Я думаю, что это вызвано некоторой проблемой с распределением памяти, но я не могу понять, почему.
Update 1 Я изменил код, чтобы использовать 3 одномерный массив для хранения текстовых сегментов, но я все еще получаю ошибку сегментации при попытке выделить память с помощью таНоса.
localText->list[i][n] = malloc(100 * sizeof(char));
ее измененный код.
typedef struct {
char name[100];
char ***list;
}text;
int main(){
int i = 0, n, z,wordCount, sections;
FILE *file;
text *localText;
openFile(&file, "test.txt");
wordCount = countWords(file);
sections = (wordCount/50) + 1;
localText = malloc(sizeof(text));
localText->list = malloc(sections * sizeof(char **));
for(i = 0; i < sections; i++)
localText->list[i] = malloc(50 * sizeof(char *));
for(n = 0; n < 50; n++)
localText->list[i][n] = malloc(100 * sizeof(char));
readFileContent(file, localText->list, 50);
freeText(localText);
return 1;
}
Вы должны запустить свою программу в отладчике. Когда он выйдет из строя, вы сможете проверить значения переменных. –
Впервые я вижу 'for (n = 0; n
@BlagovestBuyukliev: Это, вероятно, корень причина ошибки здесь. Использование 'i' для привязки массива - злая идея. – thiton