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.Есть ли какое-нибудь элегантное решение для этого?
С уважением