boost::lower_bound
Range 2.0 中(在此处找到)的实现按值获取其参数。
为什么是这样? std::lower_bound
通过 const ref 接受它的论点 - 见这里
虽然很难确定其原因,但有两点需要牢记:
按值传递的一般原因是您最终在函数中进行了复制。此外,按值传递可能会调用纯右值/xvalues 上的移动构造函数和左值上的复制构造函数。
在其实现中boost::lower_bound
使用的最新版本的 boost 库中。对于链接中提到std::lower_bound
的重载,Boost 1.59 具有以下实现:boost::lower_bound
template< class ForwardRange, class Value >
inline BOOST_DEDUCED_TYPENAME range_iterator<const ForwardRange>::type
lower_bound( const ForwardRange& rng, Value val )
{
BOOST_RANGE_CONCEPT_ASSERT(( ForwardRangeConcept<const ForwardRange> ));
return std::lower_bound(boost::begin(rng), boost::end(rng), val);
}
template< range_return_value re, class ForwardRange, class Value >
inline BOOST_DEDUCED_TYPENAME range_return<const ForwardRange,re>::type
lower_bound( const ForwardRange& rng, Value val )
{
BOOST_RANGE_CONCEPT_ASSERT(( ForwardRangeConcept<const ForwardRange> ));
return range_return<const ForwardRange,re>::
pack(std::lower_bound(boost::begin(rng), boost::end(rng), val),
rng);
}