[Thread] join_all and interrupt_all playing together
data:image/s3,"s3://crabby-images/e97d3/e97d3f3de4b64115a0ed2209b62e73d8362794f5" alt=""
I'm trying to set several threads running and have the main thread
signal an interrupt. I've included an example that shows what I'm
trying to accomplish. The threads that are created are associated with
thread_group and then a join_all is called. I would expect the main
thread to be able to call interrupt_all on the thread_group. Since this
wasn't working I looked at what the join_all and interrupt_all function
were actually doing. It turns out that thread_group has a mutex that is
being called for each function and since the mutex for join_all is in
use, the lock in interrupt_all is blocking. I understand why the mutex
is there but am unclear how interrupt_all is suppose to work with
join_all. To accomplish the functionality I need I have to use
create_thread and store the return pointer in a list of my own. Then
call interrupt on each pointer I stored. Which is basically duplicating
the storage of thread_group. This seem like a waste. I would
appreciate any advice.
Ryan
class Converter
{
public:
Converter(void) {
m_Threads.reset(new boost::thread_group);
}
void run(void) {
m_Threads->add_thread(new
boost::thread(boost::bind(&Converter::processSureTrakMessage, this)));
//m_Threads_v.push_back(m_Threads->create_thread(boost::bind(&Converter::processSureTrakMessage,
this)));
m_Threads->join_all();
m_Threads.reset(new boost::thread_group);
}
void stop(void) {
//for (std::vector
data:image/s3,"s3://crabby-images/2d876/2d8761f822017f8aa245a528aea60188ebc194c6" alt=""
Ryan McConnehey
I'm trying to set several threads running and have the main thread signal an interrupt. I've included an example that shows what I'm trying to accomplish. The threads that are created are associated with thread_group and then a join_all is called. I would expect the main thread to be able to call interrupt_all on the thread_group. Since this wasn't working I looked at what the join_all and interrupt_all function were actually doing. It turns out that thread_group has a mutex that is being called for each function and since the mutex for join_all is in use, the lock in interrupt_all is blocking. I understand why the mutex is there but am unclear how interrupt_all is suppose to work with join_all. To accomplish the functionality I need I have to use create_thread and store the return pointer in a list of my own. Then call interrupt on each pointer I stored. Which is basically duplicating the storage of thread_group. This seem like a waste. I would appreciate any advice.
There's an open trac issue about it. I'm working on boost::thread today, so I'll apply the patch. Anthony -- Author of C++ Concurrency in Action | http://www.manning.com/williams just::thread C++0x thread library | http://www.stdthread.co.uk Just Software Solutions Ltd | http://www.justsoftwaresolutions.co.uk 15 Carrallack Mews, St Just, Cornwall, TR19 7UL, UK. Company No. 5478976
participants (2)
-
Anthony Williams
-
Ryan McConnehey