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

Langage Delphi Discussion :

Tableau statique ou pile


Sujet :

Langage Delphi

  1. #1
    Membre habitué
    Profil pro
    Inscrit en
    Juillet 2007
    Messages
    203
    Détails du profil
    Informations personnelles :
    Âge : 39
    Localisation : Canada

    Informations forums :
    Inscription : Juillet 2007
    Messages : 203
    Points : 146
    Points
    146
    Par défaut Tableau statique ou pile
    Quel serait la méthode la plus efficace pour gérer plusieurs structures de données. (rapidité de lecture, d'écriture, de construction)

    Ex :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
     
    Type
      TMaStruct = record
        MaValeur : integer;
      end;
    Avec un tableau statique?

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
     
    TMaStructArray = array[0..10] of TMaStruct
    ou avec une pile?

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
     
    Type
      TMaStruct = record
        MaValeur   : integer;
        NextStruct : ^TMaStruct;
      end;
    Merci

  2. #2
    Membre éprouvé
    Avatar de CapJack
    Homme Profil pro
    Prof, développeur amateur vaguement éclairé...
    Inscrit en
    Mars 2004
    Messages
    624
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Prof, développeur amateur vaguement éclairé...
    Secteur : Enseignement

    Informations forums :
    Inscription : Mars 2004
    Messages : 624
    Points : 988
    Points
    988
    Par défaut
    Dans l'absolu, un tableau est plus rapide qu'une liste chaînée, puisqu'on accède aux éléments quasi instantanément, alors qu'une liste chaînée nécessite de parcourir toute la liste jusqu'à l'élément recherché. Les listes chaînées ne sont vraiment nécessaires que pour représenter des arborescences, et encore, même pour ça, il y a d'autres choix.

    Je vote "tableau".

  3. #3
    Membre habitué
    Profil pro
    Inscrit en
    Juillet 2007
    Messages
    203
    Détails du profil
    Informations personnelles :
    Âge : 39
    Localisation : Canada

    Informations forums :
    Inscription : Juillet 2007
    Messages : 203
    Points : 146
    Points
    146
    Par défaut
    C'est justement le cas, je désire lire la pile du début à la fin ou le tableau du début à la fin et c'est tout ...(dans les deux cas, c'est le même travail)

  4. #4
    Membre éprouvé
    Avatar de CapJack
    Homme Profil pro
    Prof, développeur amateur vaguement éclairé...
    Inscrit en
    Mars 2004
    Messages
    624
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Prof, développeur amateur vaguement éclairé...
    Secteur : Enseignement

    Informations forums :
    Inscription : Mars 2004
    Messages : 624
    Points : 988
    Points
    988
    Par défaut
    C'est une donnée qu'il fallait préciser. Dans ce cas, la liste chaînée permet d'éviter la multiplication "indice * taille d'un élément" pour accéder aux éléments, mais en contrepartie, nécessitera de coûteuses allocations de mémoire. Je donne ma langue au chat, s'il n'y a pas d'accès "au hasard" dans le tableau, il faut faire des tests de rapidité et comparer les deux. Tout dépend si la liste doit être parcourue un grand nombre de fois ou pas, je suppose.

  5. #5
    Membre habitué
    Profil pro
    Inscrit en
    Juillet 2007
    Messages
    203
    Détails du profil
    Informations personnelles :
    Âge : 39
    Localisation : Canada

    Informations forums :
    Inscription : Juillet 2007
    Messages : 203
    Points : 146
    Points
    146
    Par défaut
    nécessitera de coûteuses allocations de mémoire.
    Quelle est la différence?

    Alloué 10 structure dans un tableau ou dans une pile.

    Je ne sais pas comment delphi alloue les tableaux, sûrement :

    nombre d'indice du tableau * sizeof(Structure)?

    Sinon, Comment? Indice par indice?

  6. #6
    Membre éprouvé
    Avatar de CapJack
    Homme Profil pro
    Prof, développeur amateur vaguement éclairé...
    Inscrit en
    Mars 2004
    Messages
    624
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Prof, développeur amateur vaguement éclairé...
    Secteur : Enseignement

    Informations forums :
    Inscription : Mars 2004
    Messages : 624
    Points : 988
    Points
    988
    Par défaut
    Non, les tableaux statiques ne sont pas alloués dynamiquement sur le tas... ce sont de simples variables stockées sur la pile. C'est différent pour les tableaux dynamiques, évidemment. J'ai étudié ça à fond il y a des années, mais je ne me sens pas capable de l'expliquer en quelques phrases. Disons qu'il n'y a pas de code générant un tableau, le tableau existe à un emplacement fixe (*), et c'est tout.

    Je pense qu'il doit y avoir des tutos qui expliquent tout ça mieux que moi.

    (*) Enfin, pas vraiment, à cause de la récursivité, mais c'est tout comme, le code généré est simplement relatif au sommet de la pile.

  7. #7
    Membre habitué
    Profil pro
    Inscrit en
    Juillet 2007
    Messages
    203
    Détails du profil
    Informations personnelles :
    Âge : 39
    Localisation : Canada

    Informations forums :
    Inscription : Juillet 2007
    Messages : 203
    Points : 146
    Points
    146
    Par défaut
    Je suis un peu confus par votre dernière réponse ...

    les tableaux statiques ne sont pas alloués dynamiquement sur le tas... ce sont de simples variables stockées sur la pile.
    Ils sont tout de même alloué de la même façon que la pile précédente le ferai non?

    le tableau existe à un emplacement fixe
    Mais bon, oublions.

    En gros, il faudra que je test avec un profiler pour savoir lequel est le plus efficace.

    Si quelqu'un veut se prononcer sur le sujet, qu'il n'hésite pas, je suis preneur.

    Merci de ton aide CapJack.

  8. #8
    Membre éprouvé
    Avatar de CapJack
    Homme Profil pro
    Prof, développeur amateur vaguement éclairé...
    Inscrit en
    Mars 2004
    Messages
    624
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Prof, développeur amateur vaguement éclairé...
    Secteur : Enseignement

    Informations forums :
    Inscription : Mars 2004
    Messages : 624
    Points : 988
    Points
    988
    Par défaut
    En fait, il y a confusion des termes : tu confonds pile, et tas.

    Une page de l'excellent Marco Cantù :

    http://www.marcocantu.com/EPascal/Fr...lossaryfr.html

    Les variables allouées sur la pile ne nécessitent pas de mécanisme complexe d'allocation / désallocation.


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

Discussions similaires

  1. [Débutant] tableau d'objets => pile ou tas?
    Par gletare dans le forum C++
    Réponses: 5
    Dernier message: 21/05/2006, 23h10
  2. Réponses: 7
    Dernier message: 26/04/2006, 16h16
  3. Overflow avec tableau statique
    Par oxor3 dans le forum C++
    Réponses: 2
    Dernier message: 23/12/2005, 06h42
  4. Réponses: 7
    Dernier message: 21/12/2005, 16h44
  5. char *, string et tableau statique ou dynamique
    Par salseropom dans le forum C
    Réponses: 2
    Dernier message: 05/12/2005, 11h33

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