在使用boost :: threads时,我遇到了这个中断问题。当我在线程B上从线程A执行boost :: thread_interrupt时,虽然B禁用了中断(boost :: this_thread :: disable_interrupts di),但中断似乎丢失了。 也就是说,如果在启用中断后放入boost :: thread :: interruption_point(),则不会抛出boost :: thread_interrupted异常。
这是预期的行为还是我做错了什么?
由于
答案 0 :(得分:4)
文档中没有任何内容表明当线程B重新启用中断时会重新触发中断。我尝试过一个简单的测试程序,可以确认你描述的行为。
重新启用中断后,您可以检查this_thread::interruption_requested()
以查看在中断被禁用时是否有请求中断。如果确实要求中断,您可以自己抛出thread_interrupted
例外。
这是一个可以证明这一点的工作程序:
#include <boost/thread.hpp>
#include <iostream>
using namespace std;
using namespace boost;
void threadB()
{
int ticks = 0;
this_thread::disable_interruption* disabler = 0;
try
{
while (ticks < 20)
{
if (ticks == 5)
{
cout << "Disabling interruptions\n";
disabler = new this_thread::disable_interruption;
}
if (ticks == 15)
{
cout << "Re-enabling interruptions\n";
delete disabler;
if (this_thread::interruption_requested())
{
cout << "Interrupt requested while disabled\n";
throw thread_interrupted();
}
}
cout << "Tick " << ticks << "\n";
thread::sleep(get_system_time() + posix_time::milliseconds(100));
++ticks;
}
}
catch (thread_interrupted)
{
cout << "Interrupted\n";
}
}
int main()
{
thread b(&threadB);
thread::sleep(get_system_time() + posix_time::milliseconds(1000));
b.interrupt();
cout << "main -> Interrupt!\n";
b.join();
}
希望这有帮助。