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

Threads & Processus C++ Discussion :

openMP et allocation de pointeur


Sujet :

Threads & Processus C++

  1. #1
    Membre confirmé
    Profil pro
    Inscrit en
    Juin 2005
    Messages
    65
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juin 2005
    Messages : 65
    Par défaut openMP et allocation de pointeur
    Bonjour,

    j'ai une question à propos des allocations pointeurs avec open MP.

    Quand j'écris :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
     
    #pragma omp parallel
    {
      double* pTemp;
     
      #pragma omp single
      pTemp = double[N];
     
      #pragma omp for
      for(int i=0; i<N;i++)
        pTemp[i] = 2*i+N;
    }
    Cela veut-il dire qu'il y a autant de pointeurs dTemp créés que de threads créés pour la région parallèle ?
    Dans ce cas, quand j'alloue dynamiquement l'un des pointeurs par un seul thread avec single, et qu'ensuite j'écris dans pTemp avec une boucle for, comment sait-il que c'est dans celui alloué qu'il faut écrire ?

    Merci.


    Cordialement.

  2. #2
    Inactif  


    Homme Profil pro
    Inscrit en
    Novembre 2008
    Messages
    5 288
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 49
    Localisation : France, Rhône (Rhône Alpes)

    Informations professionnelles :
    Secteur : Santé

    Informations forums :
    Inscription : Novembre 2008
    Messages : 5 288
    Par défaut
    Bonjour

    C'est simple, il sait pas... donc il plante (ça doit dépendre de l'implémentation je pense). Il existe une clause master proche de single, qui choisit le thread principal.

    Si tu précises pas dans les pragma, les variables sont considérées en private, c'est à dire que chaque bloc utilise sa propre copie. Si on déroule :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    #pragma omp parallel // si on est sur un dual core, on créé 2 thread T1 et T2
    {
        double* pTemp; // 2 copies de cette variable, pour T1 et T2 : T1p1 et T2p1
     
        #pragma omp single // création d'une nouvelle variable : Txp2 
        pTemp = double[N];
     
        #pragma omp for // ok, pour for, les variables sont shared, on utilise donc T1p1 et T2p1
        for(int i=0; i<N;i++) 
            pTemp[i] = 2*i+N;
    }
    Citation Envoyé par ketchupi Voir le message
    Cela veut-il dire qu'il y a autant de pointeurs dTemp créés que de threads créés pour la région parallèle ?
    Oui, par exemple 2 sur un dual

    Citation Envoyé par ketchupi Voir le message
    Dans ce cas, quand j'alloue dynamiquement l'un des pointeurs par un seul thread avec single, et qu'ensuite j'écris dans pTemp avec une boucle for, comment sait-il que c'est dans celui alloué qu'il faut écrire ?
    Comme tu ne le précises pas, single est en private et tu crées une nouvelle variable dans l'un des threads. La variable du second thread n'est pas changée
    Dans tous les cas, tu as l'une de tes variables qui n'est pas allouées et qui va planter

Discussions similaires

  1. Réponses: 8
    Dernier message: 03/09/2010, 09h05
  2. Réponses: 11
    Dernier message: 01/08/2010, 14h34
  3. Allocation dynamique (pointeur passé en paramètre)
    Par sperca dans le forum Débuter
    Réponses: 6
    Dernier message: 03/02/2009, 14h50
  4. allocation et pointeur sur pointeur
    Par noobC dans le forum C
    Réponses: 7
    Dernier message: 13/11/2007, 19h00
  5. Réponses: 11
    Dernier message: 20/10/2006, 13h19

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