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 C++ Discussion :

C++11 et utilisation de la mémoire


Sujet :

Langage C++

  1. #21
    Membre éclairé

    Profil pro
    Inscrit en
    Décembre 2013
    Messages
    393
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Décembre 2013
    Messages : 393
    Points : 685
    Points
    685
    Par défaut
    @Kaamui: le but premier d'un pool d'objets est d’éviter les allocations/libérations (très coûteux) durant la boucle de jeu. On pré-alloue un tableau d'objets et dans le boucle on fait simplement passer un objet d'un état "invalide" a "valide".

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


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

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

    Informations forums :
    Inscription : Mai 2008
    Messages : 26 859
    Points : 218 580
    Points
    218 580
    Billets dans le blog
    120
    Par défaut
    Citation Envoyé par mintho carmo Voir le message
    (HS : n'oublie pas de mettre noexcept dans le constructeur par mouvement de T - si possible - pour conserver la strong garantie exception de emplace_back)
    Ça veut dire que pour toutes les classes que j'utilise dans la Pool, je dois réimplémenter le constructeur par mouvement ?
    De plus, pouvez vous me donner des détails sur le noexcept (surement pour indiquer que ma fonction ne lance pas d'exception), mais quelle est la strong garantie de emplace_back ? Genre emplace_back donne la garantie de ne pas lancer une exception ?

    C'est moi, où leur exemple ne réimplémente pas le constructeur par mouvement avec le noexcept : http://en.cppreference.com/w/cpp/con...r/emplace_back ?

    Citation Envoyé par mintho carmo Voir le message
    (HS2 : et tu devrais prendre l'habitude d'utiliser using au lieu de typedef)
    Je le fais ce soir. Merci pour la remarque.

    Une idée: un objet qui référence un int et l'incrémente à chaque copie. Vérifier ensuite que la valeur attendue est la même que le nombre de copie supposé.
    L'idée n'est pas mauvaise, si j'avais une totale maitrise des nouveaux principes de mouvement. Maintenant, cela demande de réimplémenter tous les constructeur (et opérateur de copie) possible, pour tracker ce qui se passe derrière les coulisses. C'est une chose que je vais peut être tenter, car c'est un bon exercice.
    La vérité, c'est plus : je cherchais à comprendre valgrind/massif un peu mieux, car après mes expérimentations, j'avais pas mal pataugé . Je voulais aussi éviter de faire du code pour ça.

    @Bousk : je vois. C'est une approche totalement valable .

    @Kaamui : le code est certainement compliqué. Deux raisons à cela : je m'entraine au C++11 et j'ai un peu renoncé à faire de la modélisation réflexion en amont, pour pouvoir coder, car en ce moment, je veux coder, quitte à faire plein de refactoring par la suite (et c'est ce que j'ai fait plusieurs fois déjà). Je teste la SFML aussi, mais là dessus, ça se voit moins. Donc, oui, je vous l'accorde, mon code, je le qualiferai de pourri. Surtout lorsque l'on voit ce que fait ce gars.
    Maintenant, pour le coté Pool. mintho carmo a déjà répondu à la question. Les allocations sont ultra lentes (en théorie, je dis bien en théorie car je ne l'ai jamais senti moi même). Cela est gênant dans une boucle de jeu qui doit tourner au plus sur 16ms. Surtout en utilisant std::vector, les pics de ralentissement peuvent ne pas être contrôlés (le push_back() qui alloue de la mémoire quand il "veut" dépendant de l'implémentation). Bon, sur PC, le problème est réduit, mais sur console cela pourrait être une vraie plaie. Et comme mon code est là pour m'amuser, autant faire une Pool, cela me permet d'expérimenter plus avec le emplace_back(), avec le using , avec tout....
    Mais, il y a un autre aspect, c'est que j'ai mis mes particules dans la Pool. À chaque explosion d’ennemies vous avez 100 particules qui pop pour 1 secondes et qui disparaissent. En mémoire dynamique, ça serait la mort à chaque explosion, donc la Pool. Les ennemies sont créer au fur et à mesure, ainsi que les particules. C'est pour ça que l'on ne peux pas dire juste : toutes les instances on une durée de vie fixe. Ou alors, j'ai voulu faire un pong .

    Sur console, on aime bien avoir contrôle sur tout, notamment toutes les allocations mémoire, car on est limité. Avoir une Pool, c'est dire : "J'ai un bloc pour 1000 particules, ça prend (exemple théorique) 16ko". Je ne peux pas en avoir une de plus, donc, j'ai le reste de la mémoire pour le reste de mon jeu (les textures, qui sont bien plus importantes, par exemple). Mais l'idée est aussi d'avoir un suivi bien plus précis. On peut même faire son propre alloueur de mémoire... mais ça, je n'aime pas .

    On remarquera que ma pool diminue la fragmentation. J'ai un bloc d'une taille N, je peux boucler linéairement dessus, car je l'ai alloué d'un coup au début.
    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.

+ Répondre à la discussion
Cette discussion est résolue.
Page 2 sur 2 PremièrePremière 12

Discussions similaires

  1. Utilisation de la mémoire vive par un programme
    Par Pixcoder dans le forum C++
    Réponses: 13
    Dernier message: 25/09/2006, 12h36
  2. Réponses: 21
    Dernier message: 21/07/2006, 16h55
  3. Utilisation de la mémoire dynamique
    Par Stany dans le forum Windows
    Réponses: 17
    Dernier message: 27/04/2006, 11h39
  4. Utilisation de la mémoire
    Par jagboys dans le forum MFC
    Réponses: 1
    Dernier message: 12/11/2005, 16h30
  5. Utilisation de la mémoire vive....
    Par Neilos dans le forum Windows
    Réponses: 9
    Dernier message: 24/11/2003, 11h09

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