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

Bibliothèque standard C Discussion :

lecture d'un fichier par plusieurs thread


Sujet :

Bibliothèque standard C

  1. #1
    Membre actif
    Homme Profil pro
    Étudiant
    Inscrit en
    Juin 2009
    Messages
    219
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 33
    Localisation : France

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

    Informations forums :
    Inscription : Juin 2009
    Messages : 219
    Points : 239
    Points
    239
    Par défaut lecture d'un fichier par plusieurs thread
    Bonjours à tous

    Je travail actuellement sur un système de rendu de monde 3D de très grandes tailles. Pour ne plus être limité par la mémoire vive de l'ordinateur, j'aimerai donc chargé la carte dynamiquement : je ne charge que près de la camera, et ensuite je viens chargé que ce dont j'ai besoin lord des déplacement de camera et supprimer ce dont je n'ai plus besoin. Les donnés de la carte ce trouve dans un seul fichier binaire. Un certain nombre de calcul lourd doit être ensuite effectué avant d'avoir un résultat affichable à l'écran.

    Mon idée est d'exploité le maximum des coeurs disponibles de l'ordinateur pour charger ce dont j'ai besoin le plus rapidement possible. Seulement, est il possible de faire plusieurs fopen ("mon_mega_fichier", "rb"); sur un même fichier, en même temps sur des threads différent ?

    Je vous remercie de votre lecture ainsi de vos réponses éventuels.

  2. #2
    Membre régulier
    Profil pro
    Inscrit en
    Avril 2006
    Messages
    107
    Détails du profil
    Informations personnelles :
    Localisation : France, Alpes Maritimes (Provence Alpes Côte d'Azur)

    Informations forums :
    Inscription : Avril 2006
    Messages : 107
    Points : 124
    Points
    124
    Par défaut
    Bonjour,

    Ne vaut-il mieux pas paralléliser les calculs lourds (threads ou openMP) plutôt que la lecture d'un fichier, qui doit être bien plus limitée par la vélocité du disque dur que par celle du processeur ...?

  3. #3
    Membre actif
    Homme Profil pro
    Étudiant
    Inscrit en
    Juin 2009
    Messages
    219
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 33
    Localisation : France

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

    Informations forums :
    Inscription : Juin 2009
    Messages : 219
    Points : 239
    Points
    239
    Par défaut
    L'idée de départ était de faire le processus sur "une tuile" en entier (chargement + calcul) sur un seul coeurs, et ensuite dupliqué ce processus autemps de fois qu'il y à de coeurs disponibles, pour arrivé au plus vite à la formation du "tois" entier.
    Mais j'avais oublié le détail de la lenteur du disque. Donc le mieux serai de dédier un thread pour la lecture de donnée, qui ensuite repartirai çà verts les thread esclaves qui font les calculs lourd.

    Cela me semble logique et bien plus fiable que ma solution d'origine. Merci beaucoup de votre réponse très radical à mon problème !

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

Discussions similaires

  1. Lecture d'un fichier par plusieurs threads
    Par vinzzzz dans le forum Général Java
    Réponses: 7
    Dernier message: 09/10/2009, 16h09
  2. Lecture d'un fichier son.. plusieurs fois
    Par TheBAT dans le forum Multimédia
    Réponses: 5
    Dernier message: 21/04/2009, 14h41
  3. [débutant] partage de variable par plusieurs threads
    Par dahtah dans le forum Débuter avec Java
    Réponses: 6
    Dernier message: 06/03/2007, 13h34
  4. Réponses: 12
    Dernier message: 13/01/2006, 10h14

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