OVH Cloud OVH Cloud

Erreur: pointeur nul

9 réponses
Avatar
Nicolas IG
Bonjour,
Voici un problème que j'ai du mal à résoudre:

Dans une fonction f, j'alloue une variable locale *tab de la manière
suivante:

float *tab = (float *)calloc (1024, sizeof(float));

et je la libere à la fin de la fonction avec:

free(tab);

La fonction f est utilisée 2 fois de suite dans mon programe. A la première
utilisation tout se passe normalement, tandis qu'à la 2eme utilisation, je
me retrouve avec erreur (unhandled exception) car l'adresse du tableau est
nulle!

Si quelqu'un pouvait m'orienter vers une explication d'un tel phénomen :)

9 réponses

Avatar
Thomas Abbé
Dans une fonction f, j'alloue une variable locale *tab de la manière
suivante:

float *tab = (float *)calloc (1024, sizeof(float));

et je la libere à la fin de la fonction avec:

free(tab);



tas deja utilise new et delete[]?

float* tab = new float[nombre];
...
delete[] tab;

thomas

Avatar
Jean-Marc Bourguet
"Nicolas IG" writes:

Peux-tu poster un exemple miminum compilable reproduisant le probleme?
Il est des chances que tu ne mentionnes pas un element important ou
meme que tu ne fasses pas ce que tu penses.

--
Jean-Marc
FAQ de fclc++: http://www.cmla.ens-cachan.fr/~dosreis/C++/FAQ
C++ FAQ Lite en VF: http://www.ifrance.com/jlecomte/c++/c++-faq-lite/index.html
Site de usenet-fr: http://www.usenet-fr.news.eu.org
Avatar
Rémy
"Nicolas IG" a écrit dans le message de
news:4002c25e$0$17128$
float *tab2 = new float[200];;
int i;



...

for (i 0; i<400; i++)
{
tab2[i] = (float) i;
}



Tu as là un magnifique écrasement de mémoire.

Tu déclares tab2 de 200 éléments et tu remplis les éléments de 200 à 400 !!

Pas étonnant que le programme fasse n'importe quoi après...

Rémy

Avatar
Jean-Marc Bourguet
"Nicolas IG" writes:

Peux-tu poster un exemple miminum compilable reproduisant le probleme?
Il est des chances que tu ne mentionnes pas un element important ou
meme que tu ne fasses pas ce que tu penses.


Voici un programe qui me retourne un pointeur nul sur tab1 au 3eme appel de
f:


#include <stdlib.h>

void f (void)
{
float *tab1 = new float[1024];
float *tab2 = new float[200];;
int i;

for (i 0; i<400; i++)
{
tab2[i] = (float) i;


Tu accedes en dehors de la memoire allouee (qui va de 0 a 199).
N'importe quoi peut se passer par apres.

A+

--
Jean-Marc
FAQ de fclc++: http://www.cmla.ens-cachan.fr/~dosreis/C++/FAQ
C++ FAQ Lite en VF: http://www.ifrance.com/jlecomte/c++/c++-faq-lite/index.html
Site de usenet-fr: http://www.usenet-fr.news.eu.org


Avatar
Fabien LE LEZ
On Mon, 12 Jan 2004 15:10:10 -0800, "Nicolas IG"
wrote:

Dans une fonction f, j'alloue une variable locale *tab de la manière
suivante:

float *tab = (float *)calloc (1024, sizeof(float));


Dis, t'es sûr que tu n'as pas moyen d'utiliser std::vector<> ?

--
;-)

http://www.gotw.ca/gotw/063.htm
http://www.gotw.ca/gotw/067.htm#2

Avatar
Nicolas IG
tas deja utilise new et delete[]?


Oui j'ai aussi testé cette solution, mais le résultat est toujours le même,
lors du deuxieme passage dans la fonction, le tableau est initialisé avec
une adresse nulle.
Ce phenomen d'adresse nulle est-il fréquent, et traduit-il un problème
particulier?

Avatar
Nicolas IG
Peux-tu poster un exemple miminum compilable reproduisant le probleme?
Il est des chances que tu ne mentionnes pas un element important ou
meme que tu ne fasses pas ce que tu penses.


Voici un programe qui me retourne un pointeur nul sur tab1 au 3eme appel de
f:


#include <stdlib.h>

void f (void)
{
float *tab1 = new float[1024];
float *tab2 = new float[200];;
int i;

for (i 0; i<400; i++)
{
tab2[i] = (float) i;
}

delete[] tab1;
// delete[] tab2;
return;
}

int main()
{
f();
f();
f();
return;
}

PS: Si quelqu'un peux, par la même occasion, m'expliquer pourquoi je ne peux
faire le delete[] tab2;

Avatar
Nicolas IG
Heu, oui, là c'est clair, je crois qu'il faut que j'aille boire un café!!!
Merci et encore désolé ;)


"Jean-Marc Bourguet" wrote in message
news:
"Nicolas IG" writes:

Peux-tu poster un exemple miminum compilable reproduisant le probleme?
Il est des chances que tu ne mentionnes pas un element important ou
meme que tu ne fasses pas ce que tu penses.


Voici un programe qui me retourne un pointeur nul sur tab1 au 3eme appel
de


f:


#include <stdlib.h>

void f (void)
{
float *tab1 = new float[1024];
float *tab2 = new float[200];;
int i;

for (i 0; i<400; i++)
{
tab2[i] = (float) i;


Tu accedes en dehors de la memoire allouee (qui va de 0 a 199).
N'importe quoi peut se passer par apres.

A+

--
Jean-Marc
FAQ de fclc++: http://www.cmla.ens-cachan.fr/~dosreis/C++/FAQ
C++ FAQ Lite en VF:
http://www.ifrance.com/jlecomte/c++/c++-faq-lite/index.html

Site de usenet-fr: http://www.usenet-fr.news.eu.org




Avatar
kanze
Fabien LE LEZ wrote in message
news:...
On Mon, 12 Jan 2004 15:10:10 -0800, "Nicolas IG"
wrote:

Dans une fonction f, j'alloue une variable locale *tab de la manière
suivante:

float *tab = (float *)calloc (1024, sizeof(float));


Dis, t'es sûr que tu n'as pas moyen d'utiliser std::vector<> ?


D'autant plus que je parie que son calloc ne fait pas ce qu'il pense.
std::vector initialise des float correctement -- calloc ne fait que
mettre les bits à zéro (puisqu'il ne sait pas qu'il s'agit des float),
ce qui n'est pas garantie d'être une valeur floatante légale.

S'il ne veut absolument pas de l'initialisation (disons que le profileur
lui a montré que c'est là que le programme coince), c'est alors malloc
ou l'opérator new qu'il faut utiliser. L'utilité de calloc se limite à
des tableaux de type entier.

--
James Kanze GABI Software mailto:
Conseils en informatique orientée objet/ http://www.gabi-soft.fr
Beratung in objektorientierter Datenverarbeitung
11 rue de Rambouillet, 78460 Chevreuse, France, +33 (0)1 30 23 45 16