J'essaie d'implémenter une file d'attente dans C. Venant de Java et d'autres langages gérés, je suis vraiment aux prises avec la gestion de la mémoire. Voici la fonction enqueue()
:malloc échoue de manière catastrophique
int enqueue(Queue q, int value) {
Node newNode = malloc(sizeof(Node));
/*newNode->value = value;
if (q->size == 0)
q->head = newNode;
else
q->head->next = &newNode;
q->size++;*/
}
Je reçois cette erreur:
malloc.c:3096: sYSMALLOc: Assertion `(old_top == (((mbinptr) (((char *) &((av)->bins[((1) - 1) * 2])) - __builtin_offsetof (struct malloc_chunk, fd)))) && old_size == 0) || ((unsigned long) (old_size) >= (unsigned long)((((__builtin_offsetof (struct malloc_chunk, fd_nextsize))+((2 * (sizeof(size_t))) - 1)) & ~((2 * (sizeof(size_t))) - 1))) && ((old_top)->size & 0x1) && ((unsigned long)old_end & pagemask) == 0)' failed.
FWIW, voici le reste du code (est-ce même droit?):
typedef struct NodeStruct *Node;
struct NodeStruct {
Node* prev;
Node* next;
int value;
};
typedef struct QueueStruct *Queue;
struct QueueStruct {
Node* head;
Node* tail;
int size;
int capacity;
};
Queue newQueue(int size) {
Queue q = malloc(sizeof(Queue));
q->capacity = size;
q->size = 0;
q->head = NULL;
q->tail = NULL;
return q;
}
void printQueue(Queue q) {
printf("Queue of size %d, capacity %d", q->size, q->capacity);
}
int main() {
Queue myQ = newQueue(10);
// this seems to work
printQueue(myQ);
// epic fail
enqueue(myQ, 5);
return 0;
}
Pourquoi Est-ce que cela arrive?
Le problème est arrivé bien avant cet appel à 'malloc', lorsque vous mis à mal sur le passé de quelque chose attribué par un appel précédent à' malloc' ou avec un pointeur non initialisé. Bonne chance pour le trouver. –
Même si le code est commenté, je rappellerai que 'enqueue' est vraiment faux: il enregistre l'adresse d'une variable * local * (qui ne devrait même pas compiler), et n'initialise pas les membres de 'Node'. En outre, ajouter quelque chose à une queue implique généralement d'ajouter à la queue, pas à l'élément après la tête. – jamesdlin
* Toujours * vérifier le résultat de 'malloc'! Vous pouvez utiliser un wrapper pour cela (recherchez [xmalloc] (http://gcc.gnu.org/onlinedocs/libiberty/Functions.html#index-xmalloc-202) sur Internet). S'il s'agit d'un devoir, ajoutez le tag * homework * à la question. –