Lambda 表达式

Lambda 表达式是 C++11 引入的一种匿名函数的方式,它允许你在需要函数的地方内联地定义函数,而无需单独命名函数

[capture clause](parameters) -> return_type {
 // 函数体
// 可以使用捕获列表中的变量
return expression; // 可选的返回语句
}
  • 捕获列表(Capture clause):用于捕获外部变量,在 Lambda 表达式中可以访问这些变量。捕获列表可以为空,也可以包含变量列表 [var1, var2, ...]。
  • 参数列表(Parameters):与普通函数的参数列表类似,可以为空或包含参数列表param2, ...)。
  • 返回类型(Return type):Lambda 表达式可以自动推断返回类型auto,也可以显式指定返回类型 > return_type。如果函数体只有一条返回语句,可以省略返回类型。
  • 函数体(Body):Lambda 表达式的函数体,包含需要执行的代码。
cpp 复制代码
int main(int argc, char *argv[])
{
    int x=10,y=200;
    auto add = [](int a,int b)->int{
        return a+b;
    };
    int c=add(x,y);
    cout<< c;
    return 0;

}
cpp 复制代码
int main(int argc, char *argv[])
{
    int x=10,y=200;
    auto max = [](int a,int b)->auto{
        return a  > b;
    };
    cout << max;
    return 0;

}

lambda调用错误写法:

cpp 复制代码
int main(int argc, char *argv[])
{
    int x=10,y=200;
    auto add = [x,y]()->int{
        return x+y;
    };
    cout << add;
    return 0;

}

正确写法:

cpp 复制代码
int main(int argc, char *argv[])
{
    int x=10,y=200;
    auto add = [x,y]()->int{
        return x+y;
    };
    cout << add();
    return 0;

}

这种方式捕获变量是不能修改变量的,只可读

cpp 复制代码
int main(int argc, char *argv[])
{
    int x=10,y=200;
    auto add = [x,y]()->int{
        //x++;
        //x = 15;//这种方式捕获变量是不能修改变量的,只可读
        return x+y;
    };
    int ret = add();
    cout << ret;
    return 0;

}

|-----------|----------------------|
| 捕获形式 | 含义 |
| [ ] | 空捕获(全局和局部静态仍然可见) |
| [=] | 隐式值捕获,值捕获lambda前面的变量 |
| [names] | 一个逗号分隔的捕获变量列表 |
| [&] | 隐式引用捕获 |
| [&,a] | 除了a外的所有外部变量都为引用 |
| [&x,y] | 按引用捕获x,按值捕获y |

cpp 复制代码
int main(int argc, char *argv[])
{
    static int x=10,y=200;
    auto add = []()->int{
        return x+y;
    };
    int a=10;
    int ret = add();
    cout << ret;
    return 0;

}
cpp 复制代码
int main(int argc, char *argv[])
{
    int x=10,y=200;
    auto add = [&,y]()->int{
        x++;
        return x+y;
    };
    int a=10;
    int ret = add();
    cout << ret;
    return 0;

}
cpp 复制代码
int main(int argc, char *argv[])
{
    int x=10,y=200;
    auto add = [&x,y]()->int{// 按引用捕获x,按值捕获y
        x++;
        return x+y;
    };
    int a=10;
    int ret = add();
    cout << ret;
    return 0;

}
相关推荐
墨️穹4 分钟前
DAY5, 使用read 和 write 实现链表保存到文件,以及从文件加载数据到链表中的功能
算法
sz66cm16 分钟前
算法基础 -- Trie压缩树原理
算法
Java与Android技术栈24 分钟前
图像编辑器 Monica 之 CV 常见算法的快速调参
算法
别NULL37 分钟前
机试题——最小矩阵宽度
c++·算法·矩阵
珊瑚里的鱼37 分钟前
【单链表算法实战】解锁数据结构核心谜题——环形链表
数据结构·学习·程序人生·算法·leetcode·链表·visual studio
无限码力41 分钟前
[矩阵扩散]
数据结构·算法·华为od·笔试真题·华为od e卷真题
gentle_ice42 分钟前
leetcode——矩阵置零(java)
java·算法·leetcode·矩阵
查理零世43 分钟前
保姆级讲解 python之zip()方法实现矩阵行列转置
python·算法·矩阵
zhbi981 小时前
测量校准原理
算法
时间很奇妙!1 小时前
decison tree 决策树
算法·决策树·机器学习