How to compile openmp using g++

前端 未结 2 1984
青春惊慌失措
青春惊慌失措 2020-12-08 21:01

I have a problem about the openmp compiling.

Like the following code:

#include  
#include 
#include 
#i         


        
相关标签:
2条回答
  • 2020-12-08 21:06

    The OpenMP pragmas are only enabled when compiled with -fopenmp. Otherwise they are completely ignored by the compiler. (Hence, only 1 thread...)

    Therefore, you will need to add -fopenmp to the compilation of every single module that uses OpenMP. (As opposed to just the final linking step.)

    g++ -c test.cpp -o test.o -fopenmp
    g++ test.o -o test -fopenmp -lpthread
    
    0 讨论(0)
  • 2020-12-08 21:20

    OpenMP is a set of code transforming pragmas, i.e. they are only applied at compile time. You cannot apply code transformation to an already compiled object code (ok, you can, but it is far more involving process and outside the scope of what most compilers do these days). You need -fopenmp during the link phase only for the compiler to automatically link the OpenMP runtime library libgomp - it does nothing else to the object code.

    On a side note, although techically correct, your code does OpenMP in a very non-OpenMP way. First, you have reimplemented the OpenMP sections construct. The parallel region in your main function could be rewritten in a more OpenMP way:

    #pragma omp parallel sections
    {
        #pragma omp section
        {
            cout<<"There are "<<omp_get_num_threads()<<" threads"<<endl;
            for(int i=0;i<5;i++)
                produce(i);
        }
        #pragma omp section
        {
            int x;
            while(true)
            {
                consume1(x);
                cout<<"consume1 "<<x<<endl;
            }
        }
        #pragma omp section
        {
            int x;
            while(true)
            {
                consume1(x);
                cout<<"consume2 "<<x<<endl;
            }
        }
    }
    

    (if you get SIGILL while running this code with more than three OpenMP threads, you have encountered a bug in GCC, that will be fixed in the upcoming release)

    Second, you might want to take a look at OpenMP task construct. With it you can queue pieces of code to be executed concurrently as tasks by any idle thread. Unfortunately it requires a compiler which supports OpenMP 3.0, which rules out MSVC++ from the equation, but only if you care about portability to Windows (and you obviously don't, because you are using POSIX threads).

    0 讨论(0)
提交回复
热议问题