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 :

Asynchronous File I/O


Sujet :

C++

  1. #1
    Membre habitué Avatar de Kromagg
    Homme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Août 2008
    Messages
    275
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 37
    Localisation : France, Ille et Vilaine (Bretagne)

    Informations professionnelles :
    Activité : Ingénieur développement logiciels
    Secteur : High Tech - Opérateur de télécommunications

    Informations forums :
    Inscription : Août 2008
    Messages : 275
    Points : 198
    Points
    198
    Par défaut Asynchronous File I/O
    Bonjour

    Je cherche un librairie (C/C++) pour faire des opérations asynchrones sur les fichiers, si possible multi-plateforme (Windows et Linux minimum)

    Merci bien
    Kromagg
    C'est dans ses rêves que l'homme trouve la liberté cela fut, est et restera la vérité! (John Keating - Le cercle des poètes disparus)

  2. #2
    Inactif  


    Homme Profil pro
    Doctorant sécurité informatique — Diplômé master Droit/Économie/Gestion
    Inscrit en
    Décembre 2011
    Messages
    9 012
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 31
    Localisation : France, Loire (Rhône Alpes)

    Informations professionnelles :
    Activité : Doctorant sécurité informatique — Diplômé master Droit/Économie/Gestion
    Secteur : Enseignement

    Informations forums :
    Inscription : Décembre 2011
    Messages : 9 012
    Points : 23 145
    Points
    23 145
    Par défaut
    Bonjour,

    bibliothèque*

    C/C++

    Il faut te décider C ou C++ ?

    Sinon
    http://lmgtfy.com/?q=asynchronous+files+C%2B%2B

  3. #3
    Membre habitué Avatar de Kromagg
    Homme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Août 2008
    Messages
    275
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 37
    Localisation : France, Ille et Vilaine (Bretagne)

    Informations professionnelles :
    Activité : Ingénieur développement logiciels
    Secteur : High Tech - Opérateur de télécommunications

    Informations forums :
    Inscription : Août 2008
    Messages : 275
    Points : 198
    Points
    198
    Par défaut
    Citation Envoyé par Neckara Voir le message
    bibliothèque*
    Oui désolé c'est l'habitude du mot anglais, mauvaise traduction^^

    Citation Envoyé par Neckara Voir le message

    Il faut te décider C ou C++ ?
    Je voulais dire par là en C ou C++, peu importe.

    Et la recherche google n'a rien donnée de concluant puisque je n'ai trouvé aucune bibliothèques multi-plateforme. C'est donc pour ça que je poste sur ce forum
    C'est dans ses rêves que l'homme trouve la liberté cela fut, est et restera la vérité! (John Keating - Le cercle des poètes disparus)

  4. #4
    Inactif  


    Homme Profil pro
    Doctorant sécurité informatique — Diplômé master Droit/Économie/Gestion
    Inscrit en
    Décembre 2011
    Messages
    9 012
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 31
    Localisation : France, Loire (Rhône Alpes)

    Informations professionnelles :
    Activité : Doctorant sécurité informatique — Diplômé master Droit/Économie/Gestion
    Secteur : Enseignement

    Informations forums :
    Inscription : Décembre 2011
    Messages : 9 012
    Points : 23 145
    Points
    23 145
    Par défaut
    Si j'ai bien lu, boost::asio permet de faire de la lecture aynchrone de fichier sous Windows (?) mais sous Linux, la lecture sera synchrone (car cela n'aurait pas de sens sous Linux).

    Sinon, on trouve des codes ci-et-là, un simple #ifdef et le tour est joué.

    EDIT : tu as aussi AIO pour Linux.


    Après pourquoi veux-tu faire de la lecture de fichier asynchrone?

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

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

    Informations forums :
    Inscription : Septembre 2005
    Messages : 27 369
    Points : 41 519
    Points
    41 519
    Par défaut
    Citation Envoyé par Neckara Voir le message
    Si j'ai bien lu, boost::asio permet de faire de la lecture aynchrone de fichier sous Windows (?) mais sous Linux, la lecture sera synchrone (car cela n'aurait pas de sens sous Linux).
    Pourquoi cela n'aurait-il pas de sens?
    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.

  6. #6
    Inactif  


    Homme Profil pro
    Doctorant sécurité informatique — Diplômé master Droit/Économie/Gestion
    Inscrit en
    Décembre 2011
    Messages
    9 012
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 31
    Localisation : France, Loire (Rhône Alpes)

    Informations professionnelles :
    Activité : Doctorant sécurité informatique — Diplômé master Droit/Économie/Gestion
    Secteur : Enseignement

    Informations forums :
    Inscription : Décembre 2011
    Messages : 9 012
    Points : 23 145
    Points
    23 145
    Par défaut
    Citation Envoyé par Médinoc Voir le message
    Pourquoi cela n'aurait-il pas de sens?
    Je ne sais plus exactement mais grosso-modo, si j'ai bien compris ce qui était dit :
    - les lectures sont très "rapides" ;
    - on a très souvent besoin d'attendre la fin de la lecture avant de continuer à exécuter la suite des instructions ;
    - et il y a une histoire avec le kernel Linux.

    Pour ces raisons là, la lecture asynchrone n'est pas vraiment utile sous Linux ce qui a été un frein à l'ajout complet de la lecture asynchrone dans boost.

    Je crois que cela devait être dans un sujet de stackoverflow dans les premiers liens de la recherche que j'ai posté plus haut.

    Après, je ne fais que reporter ce que j'ai cru comprendre.

  7. #7
    Membre émérite
    Avatar de imperio
    Homme Profil pro
    Étudiant
    Inscrit en
    Mai 2010
    Messages
    852
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Ain (Rhône Alpes)

    Informations professionnelles :
    Activité : Étudiant
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Mai 2010
    Messages : 852
    Points : 2 298
    Points
    2 298
    Par défaut
    @Neckara: je trouve bizarre ce que tu dis sur le coup ou alors je ne dois pas avoir la meme definition du mot asynchrone que toi...

    Prenons par exemple une ecriture de donnee asynchrone sur un fichier, elle devrait en toute logique se faire sans ralentir l'execution du programme puisqu'elle serait executee en parallele du thread principal. N'est-ce pas la le but de l'asynchronisme ?

    Citation Envoyé par Neckara
    Je ne sais plus exactement mais grosso-modo, si j'ai bien compris ce qui était dit :
    - les lectures sont très "rapides" ;
    Cette affirmation me parait fausse puisque la vitesse de lecture / ecriture d'un fichier depend surtout du materiel sur lequel il est stocke ! Sur un SSD ca sera en effet tres rapide mais pour le reste ca peut causer de grosse latence.

    Citation Envoyé par Neckara
    - on a très souvent besoin d'attendre la fin de la lecture avant de continuer à exécuter la suite des instructions ;
    Pas necessairement. Une fois de plus prenons un exemple : un jeu video tourne, tu te balades et tu as besoin de charger une nouvelle texture (tres lourde). Tu ne vas pas stopper le jeu pendant ce temps-la, ce serait inconcevable !

    Citation Envoyé par Neckara
    - et il y a une histoire avec le kernel Linux.
    La je crois qu'il va te falloir etre plus precis.

  8. #8
    Inactif  


    Homme Profil pro
    Doctorant sécurité informatique — Diplômé master Droit/Économie/Gestion
    Inscrit en
    Décembre 2011
    Messages
    9 012
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 31
    Localisation : France, Loire (Rhône Alpes)

    Informations professionnelles :
    Activité : Doctorant sécurité informatique — Diplômé master Droit/Économie/Gestion
    Secteur : Enseignement

    Informations forums :
    Inscription : Décembre 2011
    Messages : 9 012
    Points : 23 145
    Points
    23 145
    Par défaut
    Cette affirmation me parait fausse puisque la vitesse de lecture / ecriture d'un fichier depend surtout du materiel sur lequel il est stocke !
    Cela dépend aussi des optimisations qui peuvent être fait sur le code.
    Après, comme je l'ai dit, je ne fais que rapporter ce que j'ai lu.

    Citation Envoyé par imperio Voir le message
    Pas necessairement. Une fois de plus prenons un exemple : un jeu video tourne, tu te balades et tu as besoin de charger une nouvelle texture (tres lourde). Tu ne vas pas stopper le jeu pendant ce temps-la, ce serait inconcevable !
    C'est pour cela qu'on utilise des threads et des écrans de chargements.

    La je crois qu'il va te falloir etre plus precis.
    Essaye de retrouver le post car j'ai pas tout compris

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

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

    Informations forums :
    Inscription : Septembre 2005
    Messages : 27 369
    Points : 41 519
    Points
    41 519
    Par défaut
    on a très souvent besoin d'attendre la fin de la lecture avant de continuer à exécuter la suite des instructions
    Justement, la lecture asynchrone, c'est pour quand on n'en a pas besoin. Quand on a besoin du résultat tout de suite, on fait une lecture synchrone.
    Citation Envoyé par Neckara Voir le message
    C'est pour cela qu'on utilise des threads
    Traduction: Si on veut de la lecture asynchrone, on peut la faire soi-même.
    Bien que techniquement vrai, ce n'est pas forcément la solution optimale (duplication de code, réinvention de roues, etc.)
    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.

  10. #10
    Membre habitué Avatar de Kromagg
    Homme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Août 2008
    Messages
    275
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 37
    Localisation : France, Ille et Vilaine (Bretagne)

    Informations professionnelles :
    Activité : Ingénieur développement logiciels
    Secteur : High Tech - Opérateur de télécommunications

    Informations forums :
    Inscription : Août 2008
    Messages : 275
    Points : 198
    Points
    198
    Par défaut
    En fait je travaille sur un projet de jeux vidéos 2D, j'aimerai pour commencer reproduire le premier niveau de l'excellent Jazz Jack Rabbit 2 qui a bercé une partie mon enfance Et j'ai justement besoin de la lecture asynchrone pour charger le décors des niveau au fur et à mesure que le joueur progresse. J'ai pensé à développer mon système à base de thread mais pourquoi réinventer la roue.

    Est-ce que le couple std::async/std::future pourrait faire l'affaire pour ce type de tâche ?
    C'est dans ses rêves que l'homme trouve la liberté cela fut, est et restera la vérité! (John Keating - Le cercle des poètes disparus)

  11. #11
    Membre expert
    Profil pro
    Inscrit en
    Mars 2007
    Messages
    1 415
    Détails du profil
    Informations personnelles :
    Localisation : France, Paris (Île de France)

    Informations forums :
    Inscription : Mars 2007
    Messages : 1 415
    Points : 3 156
    Points
    3 156
    Par défaut
    Citation Envoyé par Kromagg Voir le message
    Est-ce que le couple std::async/std::future pourrait faire l'affaire pour ce type de tâche ?
    Très certainement !
    Find me on github

  12. #12
    Expert éminent sénior
    Avatar de koala01
    Homme Profil pro
    aucun
    Inscrit en
    Octobre 2004
    Messages
    11 614
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 52
    Localisation : Belgique

    Informations professionnelles :
    Activité : aucun

    Informations forums :
    Inscription : Octobre 2004
    Messages : 11 614
    Points : 30 626
    Points
    30 626
    Par défaut
    Salut,
    Citation Envoyé par Kromagg Voir le message
    En fait je travaille sur un projet de jeux vidéos 2D, j'aimerai pour commencer reproduire le premier niveau de l'excellent Jazz Jack Rabbit 2 qui a bercé une partie mon enfance Et j'ai justement besoin de la lecture asynchrone pour charger le décors des niveau au fur et à mesure que le joueur progresse.
    Je ne me souviens plus vraiment du jeu, mais est-ce vraiment nécessaire

    Dans la plupart des jeux 2D, l'ensemble du niveau n'est qu'une composition basée un ensemble relativement limité de "briques de base".

    Par "brique de base", j'entends bien sur les différents éléments du décors qui défile (et même, dans une certaine mesure, les différents méchants vilains pas beaux qui viennent t'embêter régulièrement )

    Une fois que tu as chargé ces "briques de base", que ce soit sous la forme de "tuiles" en jpeg ou sous la forme de dessin vectoriel + texture, "tout ce qu'il faut faire", c'est être en mesure d'indiquer quelle brique va à quel emplacement dans le décors.

    Pour peu que tu sois en mesure d'identifier clairement chaque brique de base (par exemple, au travers d'un indice de tableau), tout ton niveau peut donc se résumer en une grande matrice de n ligne et de m colonnes qui correspondent respectivement à la hauteur et à la largeur de l'intégralité du niveau envisagé et dont la correspondant à une position x, y correspond à la brique de base qu'il faut afficher pour cette position.

    Tu peux donc mettre énormément d'informations dans un espace particulièrement réduit et ton niveau peut très certainement être chargé "en entier" en mémoire, surtout quand on voit les capacités actuelles des PC en la matière

    Dés lors, n'as tu pas l'impression de te faire du mal pour rien en essayant d'utiliser la lecture asynchrone

    Maintenant, je ne dis pas que tu te fais du mal pour rien, je dis juste que tu risques ou que tu as de grandes chances de le faire
    J'ai pensé à développer mon système à base de thread mais pourquoi réinventer la roue.
    Si l'idée du thread est très certainement bonne, si tu ne devrais en effet pas avoir à réinventer la roue, je ne suis pas sur du tout que tu aies réellement besoin d'utiliser cette idée dans le contexte dans lequel tu te trouves (cf la première partie de ma réponse )

    Ma réponse n'apporte évidemment pas de solution à ton problème de lecture asynchrone, mais elle a pour but de t'ouvrir peut être d'autres pistes de réflexion qui te permettront -- qui sait -- de ne pas en avoir besoin
    A méditer: La solution la plus simple est toujours la moins compliquée
    Ce qui se conçoit bien s'énonce clairement, et les mots pour le dire vous viennent aisément. Nicolas Boileau
    Compiler Gcc sous windows avec MinGW
    Coder efficacement en C++ : dans les bacs le 17 février 2014
    mon tout nouveau blog

  13. #13
    Inactif  

    Homme Profil pro
    Ingénieur test de performance
    Inscrit en
    Décembre 2003
    Messages
    1 986
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 49
    Localisation : France, Bouches du Rhône (Provence Alpes Côte d'Azur)

    Informations professionnelles :
    Activité : Ingénieur test de performance
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Décembre 2003
    Messages : 1 986
    Points : 2 605
    Points
    2 605
    Par défaut
    Bonjour.

    Je confirme le message de koala01. On charge tous les éléments du niveau une seul fois au début.

    Le faire en court de route, c'est exposer le joueur à de bon petits lags sympas.

    Sous DirectX par exemple, on va utiliser des textures compressées au format DDS, afin de pouvoir charger la mémoire GPU au maximum.

    Je dirai que la piste des textures compressées est à envisager avant le chargement asynchrone.

  14. #14
    Membre expérimenté
    Homme Profil pro
    Inscrit en
    Décembre 2010
    Messages
    734
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations forums :
    Inscription : Décembre 2010
    Messages : 734
    Points : 1 475
    Points
    1 475
    Par défaut
    bonjour
    [vraie question inside]
    Et faire le chargement du niveau 2 en temps masqué arrivé à un certain stade du niveau 1 pour éviter une trop grosse pause, c'est pas envisageable?

  15. #15
    Expert éminent sénior
    Avatar de koala01
    Homme Profil pro
    aucun
    Inscrit en
    Octobre 2004
    Messages
    11 614
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 52
    Localisation : Belgique

    Informations professionnelles :
    Activité : aucun

    Informations forums :
    Inscription : Octobre 2004
    Messages : 11 614
    Points : 30 626
    Points
    30 626
    Par défaut
    Citation Envoyé par therwald Voir le message
    bonjour
    [vraie question inside]
    Et faire le chargement du niveau 2 en temps masqué arrivé à un certain stade du niveau 1 pour éviter une trop grosse pause, c'est pas envisageable?
    Bien sur que c'est envisageable!

    Mais cela ne nécessite toujours pas la lecture asynchrone

    Et puis, cela pourrait éventuellement poser des problèmes si le zero a encore l'occasion de mourir entre le moment où tu décides de charger le niveau suivant et le moment où il y arrive.

    La solution est peut être viable, mais il s'agit de prendre tous les aspects que cela peut impliquer en compte
    A méditer: La solution la plus simple est toujours la moins compliquée
    Ce qui se conçoit bien s'énonce clairement, et les mots pour le dire vous viennent aisément. Nicolas Boileau
    Compiler Gcc sous windows avec MinGW
    Coder efficacement en C++ : dans les bacs le 17 février 2014
    mon tout nouveau blog

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

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

    Informations forums :
    Inscription : Septembre 2005
    Messages : 27 369
    Points : 41 519
    Points
    41 519
    Par défaut
    Citation Envoyé par koala01 Voir le message
    Mais cela ne nécessite toujours pas la lecture asynchrone prise en charge par l'OS au lieu de lecture asynchrone faite toi même
    Corrigé pour toi.

    Le chargement "à l'avance" du niveau suivant ne peut être fait qu'en asynchrone. Mais ça peut être fait en asynchronisant soi-même (en faisant une lecture synchrone sur un autre thread) sans nécessiter que l'OS asynchronise pour toi.
    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.

  17. #17
    Inactif  

    Homme Profil pro
    Ingénieur test de performance
    Inscrit en
    Décembre 2003
    Messages
    1 986
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 49
    Localisation : France, Bouches du Rhône (Provence Alpes Côte d'Azur)

    Informations professionnelles :
    Activité : Ingénieur test de performance
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Décembre 2003
    Messages : 1 986
    Points : 2 605
    Points
    2 605
    Par défaut
    Bonjour.

    Citation Envoyé par therwald Voir le message
    bonjour
    [vraie question inside]
    Et faire le chargement du niveau 2 en temps masqué arrivé à un certain stade du niveau 1 pour éviter une trop grosse pause, c'est pas envisageable?
    Et bien si le premier niveau occupe 75 % de la mémoire graphique et que le deuxième niveau aussi, cela fera 150% d'occupation mémoire. Ce qui n'est pas possible...

    On pourrait toujours charger 25%. Mais le problème pourra être le lag. Si le jeu en cours d'utilisation prends 80% de la bande passante qui relie la mémoire vive à la mémoire GPU. Il ne reste que 20% pour charger les 25% de mémoire GPU. Si le processus asynchrone utilise plus de 20%, il y aura du lag. Et je pense qu'il y aura quand même du lag sur pas mal d'architecture.

    Et comme tout cela peut dépendre de plein de choses, pour être compatible multi-GPU, cela va demander beaucoup de travail. Mais pourquoi pas...

    Sous DirectX, le multithreading GPU est arrivé depuis Vista. C'est plutôt jeune comme concept.

    Donc mon conseil, lorsqu'un jeu est cours d'utilisation, il faut éviter d'en rajouter à moins de savoir ce que l'on fait, donc de l'avoir éprouver sur beaucoup d'architecture différente.

  18. #18
    Inactif  


    Homme Profil pro
    Doctorant sécurité informatique — Diplômé master Droit/Économie/Gestion
    Inscrit en
    Décembre 2011
    Messages
    9 012
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 31
    Localisation : France, Loire (Rhône Alpes)

    Informations professionnelles :
    Activité : Doctorant sécurité informatique — Diplômé master Droit/Économie/Gestion
    Secteur : Enseignement

    Informations forums :
    Inscription : Décembre 2011
    Messages : 9 012
    Points : 23 145
    Points
    23 145
    Par défaut
    Citation Envoyé par moldavi Voir le message
    Et bien si le premier niveau occupe 75 % de la mémoire graphique et que le deuxième niveau aussi, cela fera 150% d'occupation mémoire. Ce qui n'est pas possible...
    Bien sûr que c'est possible.
    Tout ça grâce à cette merveilleuse invention qu'est la mémoire SWAP .

    Après si on utilise toute la RAM + toute la mémoire SWAP, il est temps de se poser des questions...

    Après pour le reste, je ne suis pas très calé en GPU mais si on a des écrans de chargements dans les jeux pros (et sans utiliser de tiles), je pense qu'il y a une très bonne raison. S'ils pouvaient s'en passer facilement, ce serait fait depuis très longtemps je pense.

  19. #19
    Inactif  

    Homme Profil pro
    Ingénieur test de performance
    Inscrit en
    Décembre 2003
    Messages
    1 986
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 49
    Localisation : France, Bouches du Rhône (Provence Alpes Côte d'Azur)

    Informations professionnelles :
    Activité : Ingénieur test de performance
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Décembre 2003
    Messages : 1 986
    Points : 2 605
    Points
    2 605
    Par défaut
    Bonjour Neckara.

    Citation Envoyé par Neckara Voir le message
    Bien sûr que c'est possible.
    Tout ça grâce à cette merveilleuse invention qu'est la mémoire SWAP .
    Ce n'est pas bien de jouer avec les mots

    Le swap est un Fake qui te fais croire que tout est en mémoire GPU. Sauf que tu n'as plus la main au niveau optimisation. Cela risque de swapper dans tous les sens.

    Sous DirectX tu as la "Memory Managed". En gros s'il n'y a pas assez de place en mémoire GPU, ce sera en mémoire vive. Mais quand les shaders/textures sont utilisés, ils montent dans la mémoire GPU, au besoin. C'est un processus incontrôlable et source de lags.

    Si les temps de chargement des niveau 1 et 2 sont de 15 secondes, de toute façon que tu swap ou pas, il faudra 15 secondes. A un moment les ressources doivent se trouver dans la mémoire GPU. Donc qu'elle est l'intérêt de charger le niveau 2 vers la fin du niveau 1, puisque tu n'échappera pas à ces 15 secondes. Avec le risque de faire lagger le niveau 1, et pour gagner quoi. 2 secondes sur 15...

    De plus le risque, c'est que l'API décide de mettre les ressources de ton niveau 2 à la place de quelques ressources du niveau 1, qui ne sont pas utilisées depuis un moment. Malheureusement si une de ces ressources vient à être nécessaire, ça va re-swapper. Plutôt téméraire comme approche.

  20. #20
    Inactif  


    Homme Profil pro
    Doctorant sécurité informatique — Diplômé master Droit/Économie/Gestion
    Inscrit en
    Décembre 2011
    Messages
    9 012
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 31
    Localisation : France, Loire (Rhône Alpes)

    Informations professionnelles :
    Activité : Doctorant sécurité informatique — Diplômé master Droit/Économie/Gestion
    Secteur : Enseignement

    Informations forums :
    Inscription : Décembre 2011
    Messages : 9 012
    Points : 23 145
    Points
    23 145
    Par défaut
    Ah moi je pensais juste chargement en mémoire : lecture du fichier pour mettre en mémoire vive.

    Après, encore faut-il que ce soit le GPU et non le chipset graphique qui soit utilisé etc... Après... Je ne peux pas vraiment dire grand chose de plus, je ne suis vraiment pas calé dans ce domaine et je pense que tu dois t'y connaître un peu mieux que moi .

Discussions similaires

  1. Lecture synchrone et asynchrone d'une file de message
    Par asnaeb dans le forum Débuter
    Réponses: 1
    Dernier message: 09/05/2010, 18h27
  2. [File et Directory ListBox] Soucis de filtre
    Par Mercilius dans le forum Composants VCL
    Réponses: 8
    Dernier message: 04/04/2003, 16h17
  3. A propos des 'File management Functions' de Windows
    Par znaidi dans le forum Windows
    Réponses: 3
    Dernier message: 01/04/2003, 16h01
  4. recupèrer file d'attente d'impression
    Par magic corp. dans le forum Langage
    Réponses: 2
    Dernier message: 25/09/2002, 14h12
  5. Réponses: 6
    Dernier message: 25/03/2002, 21h11

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