Отладка: проблема со связью связанного списка - PullRequest
0 голосов
/ 30 мая 2020

У меня есть реализация связанного списка следующим образом:

#include <stdio.h>
#include <stdlib.h>
#include <string.h>

#define CAPACITY 128

typedef struct blob blob;
struct blob {
    char text[CAPACITY];
    struct blob* prev;
    struct blob* next;
};

static blob* create_blob() {
    blob* newBlob = malloc(sizeof(blob));
    if (!newBlob) {
        fprintf(stderr, "%s\n", "Malloc failed");
        return 0;
    }
    newBlob->prev = 0;
    newBlob->next = 0;
    memset(newBlob->text, 0, CAPACITY);
    return newBlob;
}


int insertAtTail(blob* list[static 1]) {
    blob* newBlob = create_blob();
    if (!newBlob) {
        fprintf(stderr, "%s\n", "Malloc failed");
        return 0;
    }
    if (!*list) {
        *list = newBlob;
        return 1;
    }
    blob* lastElement = *list;
    while (lastElement->next) {
        // Check if linkage until last element is okay
        if (lastElement != (lastElement->next)->prev) {
            fprintf(stderr, "%s\n", "The next_element->prev does not point to the current element");
        } else {
            fprintf(stderr, "%s\n", "Okay");
        }
        lastElement = lastElement->next; // Find last Blob
    }
    lastElement->next = newBlob;
    newBlob->prev = lastElement;
    return 1;
}

int reversePrintBlobs(blob const list[static 1]) {
    if (!list) {
        fprintf(stderr, "%s\n", "list is empty");
        return 1;
    }
    const blob* tmp = list;
    size_t blobCounter = 1;
    while (tmp->next) {
        blobCounter++;
        tmp = tmp->next;
    }
    while (tmp && tmp != list) {
        if ((tmp->prev)->next != tmp) {
            fprintf(stderr, "%s\n", "error with the linkage");
            exit(1);
        }
        printf("#number = %zu: %s\n", blobCounter--, tmp->text);
        tmp = tmp->prev;
    }
    return 0;
}

Когда я добавляю несколько больших двоичных объектов с помощью следующей функции main (), кажется, что член prev моей структуры не не указывает на предыдущий элемент. То есть проблема с привязкой. Может ли кто-нибудь указать, почему?

int main() {
    FILE* pFile = fopen("example.txt", "r");
    if (!pFile) {
        perror("fopen failed\n");
        return EXIT_FAILURE ;
    }
    fseek(pFile, 0, SEEK_SET);
    blob* list = create_blob();
    blob* tmp = list;
    while (!feof(pFile)) {
        size_t noBytesRead = fread(tmp->text, sizeof(char), CAPACITY,
                                   pFile);
        if (noBytesRead != CAPACITY && !feof(pFile)) {
            fprintf(stderr, "%s\n", "File read failed");
            exit(EXIT_FAILURE);
        }
        // Append a null terminating character in the end
        tmp->text[noBytesRead] = '\0';
        if (!feof(pFile) && insertAtTail(&list)) {
            tmp = tmp->next;
        }
    }
}

С другой стороны, если я использую следующий main (), все будет работать нормально.

int main() {
    blob* list = create_blob();
    insertAtTail(&list);
    insertAtTail(&list);
    insertAtTail(&list);
    insertAtTail(&list);
    insertAtTail(&list);
    /* code */
    return 0;
}

1 Ответ

0 голосов
/ 16 июня 2020

Ошибка исправлена, новая основная функция следующая:


int main() {
    FILE* pFile = fopen("example.txt", "r");
    if (!pFile) {
        perror("fopen failed\n");
        return EXIT_FAILURE ;
    }
    fseek(pFile, 0, SEEK_SET);
    blob* list = create_blob();
    blob* tmp = list;
    int blobCounter = 1;
    while (!feof(pFile)) {
        size_t noBytesRead = fread(tmp->text, sizeof(char), CAPACITY,
                                   pFile);
        if (noBytesRead != CAPACITY && !feof(pFile)) {
            fprintf(stderr, "%s\n", "File read failed");
            exit(EXIT_FAILURE);
        }
        // Append a null terminating character in the end
        tmp->text[noBytesRead - 1] = '\0';
        if (!feof(pFile) && insertAtTail(&list)) {
            blobCounter++;
            tmp = tmp->next;
        }
    }
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...