J'essaye d'implémenter un tableau dinamically croissant avec realloc
. Je crée le tableau avec malloc
, puis appeler ma fonction add
, ce qui augmente la taille du tableau par 1. Voici le code:realloc bug - incrémenter le dernier élément du tableau
#include <stdio.h>
#include <stdlib.h>
int *foo;
int quantity;
void add(int number) {
foo = (int*) realloc(foo, sizeof(foo) + sizeof(int));
foo[quantity] = number;
quantity++;
}
void debugFoo() {
for (int i = 0; i < quantity; i++) {
printf("foo[%i] = %i\n", i, foo[i]);
}
printf("\n");
}
int main() {
quantity = 3;
foo = (int*) malloc(quantity * sizeof(int));
foo[0] = 1;
foo[1] = 2;
foo[2] = 3;
debugFoo();
add(20);
debugFoo();
add(2);
debugFoo();
return 0;
}
Cependant quand je le lance, je reçois la sortie suivante:
foo[0] = 1
foo[1] = 2
foo[2] = 3
foo[0] = 1
foo[1] = 2
foo[2] = 3
foo[3] = 20
foo[0] = 1
foo[1] = 2
foo[2] = 3
foo[3] = 21
foo[4] = 2
Comme vous pouvez le voir, la valeur de foo [3] est incrémentée de 1 la seconde fois que j'appelle add
. Et la chose étrange est qu'il est seulement incrémenté si la première valeur passée à add
est paire. Changement de ligne 30-add(21)
, je reçois la sortie suivante:
[...]
foo[2] = 3
foo[3] = 21
foo[0] = 1
foo[1] = 2
foo[2] = 3
foo[3] = 21
foo[4] = 2
Est-ce un bug ou que j'utilise realloc
mal?
Vous n'avez pas besoin de lancer de résultat malloc. vous pouvez changer 'foo = (int *) malloc (quantité * sizeof (int));' à 'foo = malloc (quantité * sizeof * foo);' – sjsam
[Bug du compilateur] (http://c2.com/cgi/wiki? CompilerBug) –