Сериализация часть работы - boost :: asio - PullRequest
1 голос
/ 21 апреля 2011
    void wt(shared_ptr<io_service> io_servicee)
{
    io_servicee->run();
}

void calculateAndReturn(int myNumber, shared_ptr<vector<int> > vectorOfResults)
{
    /*
     * Here will be a lot of pararel computing (first part)...
     */

    int result = myNumber;

    /* This part (second part) below I want to be executed sequentially depending on the number of thread.
     * Thread which has myNumber == 1 should be first, second should be thread with
     * myNumber == 2, third with myNumber == 3 etc.
     *
     */
    mt.lock();
    vectorOfResults->push_back(result);
    mt.unlock();
}

int main()
{
    shared_ptr< io_service > io_servicee(new io_service);
    shared_ptr< io_service::work > work(new io_service::work( *io_servicee ));
    shared_ptr<vector<int> > vectorOfSums(new vector<int>);
    thread_group worker_threads;


    for( int x = 0; x < 4; ++x )
    {
            worker_threads.create_thread(bind( &wt, io_servicee ));
    }

    for( int x = 0; x < 4; ++x )
    {

        io_servicee->post(bind( &calculateAndReturn, x, vectorOfSums));
    }
    work.reset();
    worker_threads.join_all();

    for ( int i = 0; i < vectorOfSums->size(); i++)
    {
        cout << (*vectorOfSums)[i] << endl;

    }

}

Я хочу сериализовать часть функции calcAndReturn.Это должно выглядеть следующим образом:

First part of thread 1 ------->  \ 
                                  \
First part of thread 2 -------> -- Second part of thread 1 --> second part of thread2...
                                  /
     ....                        /
                                /
First part of thread n ------->/

Я не хочу использовать стренгу внутри основной функции, а не перед второй частью в calcAndReturn.Есть ли какое-нибудь элегантное решение для этого?

С уважением

1 Ответ

1 голос
/ 21 апреля 2011

Если вы делаете это за один процесс, я предлагаю использовать OpenMP .Канонический пример:

#include <omp.h>
#define N 1000
#define CHUNKSIZE  100

main ()  
{
    int i, chunk;
    float a[N], b[N], c[N];

    /* Some initializations */
    for (i=0; i < N; i++)
      a[i] = b[i] = i * 1.0;
    chunk = CHUNKSIZE;

    #pragma omp parallel for shared(a,b,c,chunk) private(i) schedule(static,chunk)
    for (i=0; i < n; i++)
        c[i] = a[i] + b[i];
}

В GNU: установите libgomp, build

g++ -fopenmp -lgomp source.cpp
...