【C/C++】Lambda 用法

Lambda 用法

1

cpp 复制代码
auto dfs = [&](auto&& dfs, int i, int j) -> int {}

这行代码定义了一个匿名的lambda表达式(也称为闭包),并将其赋值给名为dfs的变量。这个lambda表达式使用了递归和引用捕获自身的技巧,来实现深度优先搜索(Depth First Search, DFS)或其他递归算法。下面是对这行代码的详细解释:

  • auto dfs = [&](...) -> int { ... };:这部分定义了一个lambda表达式,并将其赋值给dfs变量。auto关键字用于自动推导lambda表达式的类型。[&]是捕获列表,表示以引用的方式捕获所有外部变量(包括这个lambda表达式本身,如果它在递归调用中需要)。-> int指明了这个lambda表达式的返回类型是int

【重点】

  • [&](auto&& dfs, int i, int j):这是lambda表达式的参数列表。它接受三个参数:
    • auto&& dfs:这是一个通用引用(forwarding reference),能够完美地转发其参数。在这个上下文中,它用于递归调用自身时保持类型安全。由于dfs变量本身就是这个lambda表达式的一个实例,这里通过参数传递自身实现递归调用,同时避免了在捕获列表中捕获自身导致的潜在问题(如复制或移动语义的复杂性)。
    • int iint j:这两个参数通常用于表示在某种结构(如二维数组或图)中的位置或坐标。

  • { ... }:这是lambda表达式的主体,其中应该包含实现DFS或其他递归算法的逻辑。

这种写法利用了C++11及以后版本中lambda表达式的功能,特别是完美转发和自身引用的特性,使得递归lambda表达式成为可能。它允许开发者在lambda表达式内部实现递归逻辑,而不需要定义一个单独的函数或方法。这种技巧在解决某些问题时非常有用,尤其是在需要局部定义递归算法且不希望污染全局命名空间的情况下。

然而,需要注意的是,虽然这种写法很强大,但也可能使代码难以理解和维护,特别是对于那些不熟悉lambda表达式和递归技巧的读者。因此,在使用这种技术时,应该权衡其带来的便利性和代码的可读性。

相关推荐
脏脏a24 分钟前
类和对象(下):初始化列表、静态成员与友元深度解析
开发语言·c++
Dream it possible!29 分钟前
LeetCode 面试经典 150_二叉树_二叉树中的最大路径和(77_124_C++_困难)(DFS)
c++·leetcode·面试·二叉树
2501_9411116835 分钟前
模板编译期哈希计算
开发语言·c++·算法
Creeper.exe1 小时前
【C语言】分支与循环(上)
c语言·开发语言
序属秋秋秋1 小时前
《Linux系统编程之进程基础》【进程状态】
linux·运维·c语言·c++·笔记·操作系统·进程状态
小龙报1 小时前
《嵌入式成长系列之51单片机 --- 固件烧录》
c语言·开发语言·单片机·嵌入式硬件·51单片机·创业创新·学习方法
利刃大大2 小时前
【c++中间件】etcd存储系统 && 服务注册 && 服务发现 && 二次封装
c++·中间件·服务发现·etcd·服务中心
Yue丶越2 小时前
【C语言】深入理解指针(四)
java·c语言·算法
报错小能手2 小时前
C++笔记 仿函数(函数对象)
开发语言·c++·笔记
草莓熊Lotso2 小时前
《算法闯关指南:优选算法--模拟》--39.替换所有问号,40.提莫攻击
开发语言·c++·算法·模拟