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;

}
相关推荐
心中有国也有家10 小时前
cann-recipes-infer:昇腾 NPU 推理的“菜谱集合”
经验分享·笔记·学习·算法
绝知此事11 小时前
【算法突围 01】线性结构与哈希表:后端开发的收纳术
java·数据结构·算法·面试·jdk·散列表
碧海银沙音频科技研究院11 小时前
通话AEC与语音识别AEC的软硬回采链路
深度学习·算法·语音识别
csdn_aspnet11 小时前
Python 算法快闪 LeetCode 编号 70 - 爬楼梯
python·算法·leetcode·职场和发展
LuminousCPP12 小时前
数据结构 - 线性表第四篇:C 语言通讯录优化升级全记录(踩坑 + 思考)
c语言·开发语言·数据结构·经验分享·笔记·学习
AI算法沐枫12 小时前
深度学习python代码处理科研测序数据
数据结构·人工智能·python·深度学习·决策树·机器学习·线性回归
m0_6294947314 小时前
LeetCode 热题 100-----26.环形链表 II
数据结构·算法·leetcode·链表
壹号用户14 小时前
用队列实现栈
数据结构·算法
做人求其滴15 小时前
面试经典 150 题 380 274
c++·算法·面试·职场和发展·力扣