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 :

Temps d'éxecution en C


Sujet :

C

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre éclairé Avatar de chercheur111
    Profil pro
    Étudiant
    Inscrit en
    Juillet 2010
    Messages
    352
    Détails du profil
    Informations personnelles :
    Localisation : Tunisie

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Juillet 2010
    Messages : 352
    Par défaut Temps d'éxecution en C
    Bonjour;

    S'il vous plait qui augmente le plus le temps d'exécution de l'initialisation d'un tableau ,, alloué dynamiquement ou bien déclaré statiquement.

    Merci

  2. #2
    Responsable 2D/3D/Jeux


    Avatar de LittleWhite
    Homme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Mai 2008
    Messages
    27 129
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Ingénieur développement logiciels

    Informations forums :
    Inscription : Mai 2008
    Messages : 27 129
    Billets dans le blog
    149
    Par défaut
    Bonjour,

    L'allocation dynamique va légèrement être plus couteuse en temps que l'allocation statique (car l'allocation statique n'est pas vraiment une allocation à l'exécution).

    Mais je ne pense pas que cela soit un argument pour choisir en statique et dynamique (à part peut être dans les programme qui doivent tout faire à la microseconde précise :p )
    Vous souhaitez participer à la rubrique 2D/3D/Jeux ? Contactez-moi

    Ma page sur DVP
    Mon Portfolio

    Qui connaît l'erreur, connaît la solution.

  3. #3
    Membre Expert
    Profil pro
    Inscrit en
    Août 2006
    Messages
    1 104
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Août 2006
    Messages : 1 104
    Par défaut
    S'il vous plait qui augmente le plus le temps d'exécution de l'initialisation d'un tableau ,, alloué dynamiquement ou bien déclaré statiquement.
    S'il s'agit simplement du temps d'exécution de l'initialisation d'un tableau, je suppose que c'est kifkif, quel que soit le type de tableau. Je suppose que le microprocesseur ne voit pas la différence entre une adresse mémoire à remplir sur une zone correspondant au tas et une autre correspondant à une zone du programme (pile, zone statique, etc) : une adresse est une adresse. La vérification, de la part du microprocesseur, de l'accès mémoire sur une zone permise ou non se fait à chaque accès, je pense.
    Je pense que ce qui diffère au niveau du temps sont les instructions utilisées pour initialiser le tableau. Il existe plusieurs instructions ASM qui permettent de faire la même chose et même plusieurs façon de les utiliser : certaines méthodes / certaines instructions sont plus rapides que d'autres.
    De même, cela dépend si le tableau contient les mêmes valeurs. Si c'est le cas, il y a moyen d'optimiser l'initialisation.

    Concernant le temps de création d'un tableau, c'est autre chose.
    Un tableau local non statique est créé sur la pile. Le tableau est juste un espace sur la pile, dont la taille dépend (forcément) de la taille du tableau : le registre EBP utilisé avec un index (EXP+xx) permet d'accéder à un élément du tableau ou à un autre objet local.
    Les tableaux locaux statiques et les tableaux globaux sont créés ailleurs que sur la pile. Ils sont créés avec le programme et détruits avec : on ne peut pas les détruire lors de l'exécution.

    Par contre, si le tableau est créé sur le tas, c'est différent, car on peut le créer et le détruire quand on veut. La fonction d'allocation doit donc gérer les zones libres et celles déjà occupées (c'est effectué grâce à une liste chainée d'après ce que j'ai compris), c'est donc plus gourmand en ressources puisqu'il faut chercher là où il y a de la place.

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

Discussions similaires

  1. [Framework] Temps d'éxecution Requête Dao
    Par w3blogfr dans le forum Spring
    Réponses: 2
    Dernier message: 07/01/2010, 15h24
  2. C# : calculer le temps d'éxecution
    Par Leelith dans le forum C#
    Réponses: 2
    Dernier message: 22/11/2009, 09h41
  3. Temps d'éxecution d'une requête longue
    Par Adm_Antonio dans le forum Administration
    Réponses: 13
    Dernier message: 04/06/2008, 15h11
  4. calcul temps d'éxecution d'une fonction
    Par psycho_xn dans le forum C
    Réponses: 8
    Dernier message: 02/02/2008, 19h31
  5. Réponses: 4
    Dernier message: 24/11/2005, 08h34

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