C++——Lambda表达式

0.使用场景---只有一两个地方使用的简单操作

独立出来一个函数,但这个函数实现相对简单并且可能在整个项目只使用了一次(即不存在复用的情况),那么这个时候我们就可以考虑使用下lambda表达式了。

?既然只使用一次,那直接写全代码不久醒了,为啥要函数呢?——因为lambda可以捕获局部变量

bool check_size(const string &s, string::size_type sz)
{
    return s.size() >= sz;
}

//wc:第一个满足size>sz的元素 auto wc
= find_if (words.begin(),words.end(),[sz](const string &a) {return a.size()>=sz;});

函数check_size()无法作为find_if的参数。而且需要考虑如何

 

参考:https://blog.csdn.net/qq_34199383/article/details/80469780

0.1 比较大小

//1.传统方法
#include <iostream>
#include <vector>
#include <algorithm>
using namespace std;

bool compare(int& a, int& b)
{
    return a > b;
}

int main(void)
{
    int data[6] = { 3, 4, 12, 2, 1, 6 };
    vector<int> testdata;
    testdata.insert(testdata.begin(), data, data + 6);
    // 排序算法
    sort(testdata.begin(), testdata.end(), compare);    // 升序

    return 0;
}
/*******************************************/
//2.lambda表达式
#include <iostream>
#include <vector>
#include <algorithm>
using namespace std;

int main(void)
{
    int data[6] = { 3, 4, 12, 2, 1, 6 };
    vector<int> testdata;
    testdata.insert(testdata.begin(), data, data + 6);

    sort(testdata.begin(), testdata.end(), [](int a, int b){ return a > b; });

    return 0;
}

0.2 auto 和function 接受lambda表达式的返回

#include <iostream>
#include <functional>
using namespace std;

int main(void)
{
    int x = 8, y = 9;
    auto add = [](int a, int b) { return a + b; };
    std::function<int(int, int)> Add = [=](int a, int b) { return a + b; };

    cout << "add: " << add(x, y) << endl;//17
    cout << "Add: " << Add(x, y) << endl;//17

    return 0;
}

0.3 使用lambda表达式来实现递归算法

#include <iostream>
#include <functional>
using namespace std;

int main(void)
{
    std::function<int(int)> recursion = [&recursion](int n) { 
        return n < 2 ? 1 : recursion(n - 1) + recursion(n - 2); 
    };

    // 我们来检测下我们的结果
    cout << "recursion(2):" << recursion(2) << endl;//2
    cout << "recursion(3):" << recursion(3) << endl;//3
    cout << "recursion(4):" << recursion(4) << endl;//5

    return 0;
}

0.4  重用代码段,但是避免函数传很多参数

void TestFun()
{
    int a, b, c;
    .....    // 巴拉巴拉的一堆变量

    // 代码块改成如下 使用&还是=或者既有&又有=根据自己实际情况决定
    // param可以看做这个lambda中不同的变量
    auto lambdaFun = [&](int param) -> void {
        // 这里是可以直接调用到TestFun中的变量
        // 使用a、b、c....一堆变量
    }

    if (条件1)
    {
        lambdaFun(param1);
    }
    if (条件2)
    {
        lambdaFun(param2);
    }
    if (条件3)
    {
        lambdaFun(param3);
    }
}

 

 

 

1.本质:未命名的内联函数

[capture list] (parameter list) ->return type 
{ 
    function body
}
//capture list 捕获列表,函数中定义的局部变量列表,通常为空
//lambda表达式必须使用尾置返回——return **

2.可以忽略返回类型,参数列表,但必须包含捕获列表和函数体

auto f =[] {return 42;}

3.捕获列表

auto wc = find_if(words.begin(), words.end(),[sz](const string &a) { return a.size() >= sz;} );

 4.变量截取的方式

  • [] 不截取任何变量
  • [&] 截取外部作用域中所有变量,并作为引用在函数体中使用
  • [=] 截取外部作用域中所有变量,并拷贝一份在函数体中使用
  • [=, &foo] 截取外部作用域中所有变量,并拷贝一份在函数体中使用,但是对foo变量使用引用
  • [bar] 截取bar变量并且拷贝一份在函数体重使用,同时不截取其他变量
  • [this] 截取当前类中的this指针。如果已经使用了&或者=就默认添加此选项。

 5.lambda表达式产生的类不含有默认构造函数、赋值运算符、默认析构函数;

 6.lambda表达式是一种简易的定义函数对象类的方式。??如何定义?有何用处?

 

l参考:

https://www.cnblogs.com/smiler/p/4095723.html

 

5.返回类型:单一的return语句;多语句则默认返回void;否则报错,应指定返回类型

//正确,单一return语句
transform(vi.begin(),vi.end(),vi.begin(), [] (int i) { 
    return i<0? -i; i;});

//错误。不能推断返回类型
transform(vi.begin(),vi.end(),vi.begin(), [] (int i) { 
    if (I<0) return -i;
    else return i;})

//正确,尾置返回类型
transform(vi.begin(),vi.end(),vi.begin(), [] (int i) ->int
{     if (I<0) return -i;
    else return i;})

 

6.bind()

7.using std::placeholders::_1;

8.示例

stable_sort(words.begin(), words.end(), [](const string& a, const string& b)
    {    return a.size()<b.size();});
class ShorterString{
public:
    bool opereator()(const string &s1,const string &s2) const
        {return s1.size()<s2.size();} 
};
stable_sort(words.begin(), words.end(), ShorterString{));
auto wc = find_if(words.begin(), words.end(), [sz] (const string& a)
    {  return a.size()>=sz;});//返回第一个指向满足条件元素的迭代器
class SizeComp{
    SizeComp(size_t n):sz(n) { }
    bool operator()(const string &s) const
    { return s.size()>=sz;}
private:
    size_t sz;
};

auto wc = find_if(words.begin(), words.end(),SizeComp(sz));

 

posted @ 2019-09-13 21:03  寒江小筑  阅读(964)  评论(0编辑  收藏  举报