在学习java的函数式编程思想后,发现这样的编程方式值得的学习,故用C++模拟实现一个简易的Predicate。欢迎大家指正。
代码如下:
template<typename T> class Predicate { typedef std::function<bool(const T&)> PredicateType; public: Predicate(const PredicateType& cur) :m_cur(cur) { //std::cout << "PredicateType con : " << this << std::endl; } ~Predicate() { //std::cout << "des : " << this << std::endl; } Predicate Add(const PredicateType& other) const { return Predicate([&](const T& a) { return m_cur(a) && other(a); }); } Predicate Or(const PredicateType& other) const { return Predicate([&](const T& a) { return m_cur(a) || other(a); }); } Predicate Negate()const { return Predicate([&](const T& a) { return !m_cur(a); }); } bool operator()(const T& a)const { return m_cur(a); } private: PredicateType m_cur; };
测试代码如下:
int main(int argc, char* argv[]) { Predicate<int> p([](int a) { return a > 5; }); auto ret = p.Or([](int a) {return a < 1; }) .Add([](int a) {return a > -1; }) .Negate() (-1); std::cout << std::boolalpha << ret << std::endl; return 0; }
输出结果如下: