boost::barrier是多线程的同步点,构造函数会要求传递一个数字,表示需要同步多少个线程。只有指定个数的线程到达这个点之后,程序才会继续往下走,否则会阻塞。其实barrier的同步原理很简单。
要明白它的同步原理,我们首先来看barrier的源码:
class barrier
{
static inline unsigned int check_counter(unsigned int count)
{
if (count == 0) boost::throw_exception(
thread_exception(system::errc::invalid_argument, "barrier constructor: count cannot be zero."));
return count;
}
struct dummy
{
};
public:
BOOST_THREAD_NO_COPYABLE( barrier)
explicit barrier(unsigned int count) :
m_count(check_counter(count)), m_generation(0), fct_(BOOST_THREAD_MAKE_RV_REF(thread_detail::default_barrier_reseter(count)))
{
}
template <typename F>
barrier(
unsigned int count,
BOOST_THREAD_RV_REF(F) func