本文整理汇总了C++中ThreadPool::FlushOne方法的典型用法代码示例。如果您正苦于以下问题:C++ ThreadPool::FlushOne方法的具体用法?C++ ThreadPool::FlushOne怎么用?C++ ThreadPool::FlushOne使用的例子?那么, 这里精选的方法代码示例或许可以为您提供帮助。您也可以进一步了解该方法所在类ThreadPool
的用法示例。
在下文中一共展示了ThreadPool::FlushOne方法的1个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的C++代码示例。
示例1: Trim
void Trim (std::map < int, std::vector< FORMAT<TUPLETYPE> > >* result2, int nthreads)
{
if ( (*result2)[0].size()==0 )
return;
this->check_read_length (result2);
auto job_count = std::min ( this->parameter_trait.num, std::min ( (*result2)[0].size(), (*result2)[1].size() ) );
std::vector<size_t> index_vec;
if (job_count >= this->parameter_trait.pool_size)
{
size_t dif = job_count/this->parameter_trait.pool_size;
for (size_t i=0; i!=this->parameter_trait.pool_size; ++i)
{
index_vec.push_back (
ptr_to_GlobalPool_peat_ -> JobPost (
boost::bind (
&PairEndAdapterTrimmer_impl <FORMAT, TUPLETYPE, TRAIT >::TrimImpl,
this, result2, boost::ref ( (*trim_position)[i] ), i*dif, dif
)
)
);
}
for (auto& i : index_vec)
ptr_to_GlobalPool_peat_->FlushOne (i);
}
else
this->TrimImpl (result2, (*trim_position)[0], 0, job_count);
}