티스토리 뷰

la fermata, 개발/OpenMP

shared, private 비교

창공미나래 2019. 2. 19. 23:01

#include <stdio.h>
#include <omp.h>

#define N 20

int main(int argc, char** argv)
{
    int i, j;
    int a[N];

    if(argc < 2)
        return 0;

    int nn = atoi(argv[1]);

    if(nn == 0)
    {
#pragma omp parallel for shared(j)
        for(i = 0; i < N ; i++)
        {
            int sum = 0;
            for(j = 0; j < i ; j++)
            {
                a[i] += j;
            }
        }
    } 
    else if (nn == 1)
    {
#pragma omp parallel for private(j)
        for(i = 0; i < N ; i++)
        {
            int sum = 0;
            for(j = 0; j < i ; j++)
                a[i] += j;
        }
    }
    else if (nn == 2)
    {
#pragma omp parallel for
        
            for(i = 0 ; i < N ; i++ )
            {
                int j = 0;
                for(j = 0; j < i ; j++)
                    a[i] += j;
            }
        
    }
    for(i = 0; i < N ; i++)
    {
        printf("%d\n",a[i]);
    }
    return 0;
}

공지사항
최근에 올라온 글
최근에 달린 댓글
Total
Today
Yesterday
링크
TAG
more
«   2024/05   »
1 2 3 4
5 6 7 8 9 10 11
12 13 14 15 16 17 18
19 20 21 22 23 24 25
26 27 28 29 30 31
글 보관함