通过C中的引用传递std algos谓词

前端之家收集整理的这篇文章主要介绍了通过C中的引用传递std algos谓词前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
我正在尝试从std :: list中删除元素,并保留已删除元素的一些统计信息.

为了做到这一点,我从列表中使用remove_if函数,我有一个谓词.我想使用这个谓词来收集统计信息.以下是谓词的代码

class TestPredicate
  {
  private:
    int limit_;

  public:
    int sum;
    int count;
    TestPredicate(int limit) : limit_(limit),sum(0),count(0) {}

    bool operator() (int value) 
    {
      if (value >= limit_)
      {
        sum += value;
        ++count;       // Part where I gather the stats
        return true;
      }
      else
        return false;
    }
  };

这里是algo的代码

std::list < int > container;
container.push_back(11);
TestPredicate pred(10);
container.remove_if(pred)
assert(pred.count == 1);

不幸的是,断言是false,因为谓词是通过值传递的.有没有办法强迫它通过引用传递?

解决方法

传递参考包装器,可从< functional&gt ;::
container.remove_if(std::ref(pred));

如果您只有C 98/03但编译器有TR1,则可以使用< tr1 / functional>和std :: tr1 :: ref如果你对你的谓词做了一个小的修改

#include <tr1/functional>

class TestPredicate : public std::unary_function<int,bool>
{                 //^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
  // ...
}

container.remove_if(std::tr1::ref(pred));

如果一切都失败,那么您可以轻松地使用手动解决方案:

struct predref
{
  TestPredicate & p;
  bool operator()(int n) { return p(n); }
  predref(TestPredicate & r) : p(r) { }
};

container.remove_if(predref(pred));

猜你在找的C&C++相关文章