IdentifiantMot de passe
Loading...
Mot de passe oublié ?Je m'inscris ! (gratuit)
Navigation

Inscrivez-vous gratuitement
pour pouvoir participer, suivre les réponses en temps réel, voter pour les messages, poser vos propres questions et recevoir la newsletter

 C Discussion :

Retourner un tableau dynamique


Sujet :

C

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Nouveau membre du Club
    Inscrit en
    Mai 2008
    Messages
    8
    Détails du profil
    Informations forums :
    Inscription : Mai 2008
    Messages : 8
    Par défaut Retourner un tableau dynamique
    Bonjour vous
    Tout nouveau sur ce forum, je me permet de poser une question

    Je suis entrain de creer une fonction recursive visant a creer un tableau qui contiendra un triangle de sierpinsky (c'est une fractale).
    J'ai une consigne quand aux donnees envoyees a la fonction : uniquement une puissance de deux qui sera la taille du tableau

    A chaque appel de la fonction, je recupere le tableau qui se remplit donc au fur et a mesure
    Comme on ne sait pas quelle taille fera le triangle, le tableau est alloue dynamiquement : pour liberer la memoire, j'utilise bien sur free(array). Mon probleme vient du fait que je ne peux pas liberer la memoire APRES le retour de la fonction et que si je libere la memoire avant, je ne peux pas renvoyer le tableau.

    Voila des portions de mon code pour etre plus clair :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
    26
    27
    28
    29
    30
    31
    32
    33
    34
    int main()
    {
      int i, j, power;
      int **sierpinsky_a = NULL;
     
      /* On prend par exemple power = 16 */
      power = 16;
      [...] /* Allocation Dynamique du tableau a deux dimensions **sierpinsky_a */
      **sierpinsky_a = create_array(power);
      [...] /* Traitement du tableau retourne puis liberation de la memoire. */
      return (0);
    }
     
    int create_array(int power)
    {
      int i, j, k, l, sier_size, temp_size;
      int **sierpinsky_a = NULL;
      int **temp_a = NULL;
     
      [...] /* Allocation dynamique de mes deux tableaux et initialisations des variables */
      if (power > 2)
        {
           **sierpinsky_a = create_array(power/2);
        }
      [...] /* Remplissage du tableau temp_a par rapport a sierpinsky_a */
     
      for (i = 0; i < sier_size; i++)
        {
           free(sierpinsky_a);
        }
       free(sierpinsky_a);
       return (**temp_a);
      /* Et c'est pour ce return que ca peche : je peux pas le desallouer ici, ni plus haut. */ 
    }
    Merci pour votre aide qui me sera surement precieuse. C'est pas la premiere fois que j'ai ce probleme.

  2. #2
    Expert éminent
    Avatar de Médinoc
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Septembre 2005
    Messages
    27 395
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 41
    Localisation : France

    Informations professionnelles :
    Activité : Développeur informatique
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Septembre 2005
    Messages : 27 395
    Par défaut
    Si une fonction retourne un pointeur vers une zone mémoire allouée dynamiquement, c'est à la fonction appelante de libérer cette mémoire.
    SVP, pas de questions techniques par MP. Surtout si je ne vous ai jamais parlé avant.

    "Aw, come on, who would be so stupid as to insert a cast to make an error go away without actually fixing the error?"
    Apparently everyone.
    -- Raymond Chen.
    Traduction obligatoire: "Oh, voyons, qui serait assez stupide pour mettre un cast pour faire disparaitre un message d'erreur sans vraiment corriger l'erreur?" - Apparemment, tout le monde. -- Raymond Chen.

  3. #3
    Nouveau membre du Club
    Inscrit en
    Mai 2008
    Messages
    8
    Détails du profil
    Informations forums :
    Inscription : Mai 2008
    Messages : 8
    Par défaut
    Meme en sachant que create_array() est recursive et s'appelle elle-meme ?

    Suffit de liberer dans le main ?

  4. #4
    Membre expérimenté
    Profil pro
    Inscrit en
    Mai 2008
    Messages
    145
    Détails du profil
    Informations personnelles :
    Localisation : France, Paris (Île de France)

    Informations forums :
    Inscription : Mai 2008
    Messages : 145
    Par défaut
    Il n'y a pas de garbage collector implémenté au niveau de l'OS.
    Il faut donc libérer chaque bloc alloué un à un.

  5. #5
    Nouveau membre du Club
    Inscrit en
    Mai 2008
    Messages
    8
    Détails du profil
    Informations forums :
    Inscription : Mai 2008
    Messages : 8
    Par défaut
    Pourrais-tu etre plus clair ? J'ai pas compris.

    Merci

    Si je dois desallouer un a un les blocs, je le fais dans le main ou dans la fonction ?
    Si j'ai bien compris ce qu'on a dit plus haut c'est dans le main, mais apres...

  6. #6
    Expert confirmé
    Avatar de diogene
    Homme Profil pro
    Enseignant Chercheur
    Inscrit en
    Juin 2005
    Messages
    5 761
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Essonne (Île de France)

    Informations professionnelles :
    Activité : Enseignant Chercheur
    Secteur : Enseignement

    Informations forums :
    Inscription : Juin 2005
    Messages : 5 761
    Par défaut
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
      int **sierpinsky_a = NULL;
    ...
      [...] /* Allocation Dynamique du tableau a deux dimensions **sierpinsky_a */
      **sierpinsky_a = create_array(power);
      [...] /* Traitement du tableau retourne puis liberation de la memoire. */
    Si create_array crée le tableau, il doit retourner son adresse. Or **sierpinsky_a est un int, pas un pointeur.
    On attend plutôt :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    sierpinsky_a = create_array(power);
    Pour la question de la libération mémoire allouée dans create_array, il faudrait un peu plus de code de create_array pour comprendre le détail des allocations (compliqué par le fait de la récursivité). Ce qui est sûr, c'est que tout ce qui ne peut être libéré par l'intermédiaire de sierpinsky_a dans le main doit l'être directement dans create_array

  7. #7
    Membre expérimenté
    Profil pro
    Inscrit en
    Mai 2008
    Messages
    145
    Détails du profil
    Informations personnelles :
    Localisation : France, Paris (Île de France)

    Informations forums :
    Inscription : Mai 2008
    Messages : 145
    Par défaut
    Citation Envoyé par Diacred Voir le message
    Si je dois desallouer un a un les blocs, je le fais dans le main ou dans la fonction ?
    Si j'ai bien compris ce qu'on a dit plus haut c'est dans le main, mais apres...
    La désallocation peut se faire à n'importe quel endroit du code, mais je vais prendre un exemple pour être plus clair.

    Admettons un pointeur de structure que nous appelerons pstruct. Dans le cas d'un malloc, pstruct va pointer sur un bloc mémoire :
    Mais dans pstruct, certains champs peuvent eux mêmes être des pointeurs et on pourrait donc avoir un truc du genre :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
     
    pstruct -> bloc1 -- champ_truc -> bloc2
                   \---- champ bidule -> bloc3
    Pour libérer la mémoire, il faut libérer les 3 blocs individuellement, un à un. On ne peut pas juste faire un free(bloc1).
    C'est ce que je voulais dire plus haut.

  8. #8
    Expert éminent
    Avatar de Emmanuel Delahaye
    Profil pro
    Retraité
    Inscrit en
    Décembre 2003
    Messages
    14 512
    Détails du profil
    Informations personnelles :
    Âge : 68
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Retraité

    Informations forums :
    Inscription : Décembre 2003
    Messages : 14 512
    Par défaut
    Citation Envoyé par Diacred Voir le message
    Voila des portions de mon code pour etre plus clair :
    Ce code ne s'exécute pas (crash). Il doit manquer des choses ([...] ?). On doit deviner ?

  9. #9
    Nouveau membre du Club
    Inscrit en
    Mai 2008
    Messages
    8
    Détails du profil
    Informations forums :
    Inscription : Mai 2008
    Messages : 8
    Par défaut
    -Ed-, il est dans le message precedent le tien, complet et fonctionnel.

    J'avais mis des [...] car je recopiais le programme depuis un autre PC, sans moyen de transfert. Je n'avais donc recopie que les parties qui me semblaient utiles

+ Répondre à la discussion
Cette discussion est résolue.

Discussions similaires

  1. Réponses: 4
    Dernier message: 19/03/2015, 18h31
  2. Retourner un tableau dynamique
    Par wkd dans le forum C
    Réponses: 5
    Dernier message: 01/01/2006, 11h33
  3. AFFICHER UN TABLEAU DYNAMIQUE
    Par ghassenus dans le forum Langage
    Réponses: 2
    Dernier message: 28/12/2002, 14h19
  4. [Kylix] tableau dynamique
    Par sdoura2 dans le forum EDI
    Réponses: 1
    Dernier message: 31/10/2002, 08h57
  5. Réponses: 4
    Dernier message: 13/05/2002, 16h43

Partager

Partager
  • Envoyer la discussion sur Viadeo
  • Envoyer la discussion sur Twitter
  • Envoyer la discussion sur Google
  • Envoyer la discussion sur Facebook
  • Envoyer la discussion sur Digg
  • Envoyer la discussion sur Delicious
  • Envoyer la discussion sur MySpace
  • Envoyer la discussion sur Yahoo