针对上一篇用 lambda替换了 仿函数,接下来探究下是否能用 仿函数代替 lambda

本文探讨了在C++中使用仿函数(functors)替代lambda表达式以及反过来的情况。通过一个示例展示了如何用仿函数实现自定义排序,并与lambda表达式的使用进行对比。实验表明,尽管可以使用仿函数代替lambda,但lambda的语法更加简洁。文章通过一个`sort()`函数测试,演示了如何使用仿函数和lambda进行升序和降序排序。
摘要由CSDN通过智能技术生成

在上一篇中用 lambda替换了 仿函数,接下来探究下是否能用 仿函数代替 lambda

测试:

写一个 sort() 函数测试

结论:

是可以的,不过这里仿函数要加一个() 实例化

#include <iostream>
#include <algorithm>
#include <vector>

// 写仿函数
class Cmp{
public:
    bool operator()( const int& a, const int& b ) const{
        return a >= b;
    }
};

int main( ){
    std::vector<int> nums{1, 7, 20, 9, 23, 98, 23};

    // 正常排序,无参数
    sort( nums.begin(), nums.end() );
    for( auto& num : nums ){
        std::cout << num << "  ";
    }
    std::cout << std::endl;

    // 自定义排序
    sort( nums.begin(), nums.end(), Cmp() );
    for( auto& num : nums ){
        std::cout << num << "  ";
    }
    std::cout << std::endl;

    // 写 lambda
    sort( nums.begin(), nums.end(), [](const int& a, const int&b){return a <= b;}  
        );
    for( auto& num : nums ){
        std::cout << num << "  ";
    }
    std::cout << std::endl;

    return 0;
}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值