【C++】lambda表达式

Lambda表达式

  • 完整结构

    [capture list] (params list) mutable exception -> return type { function body }

在这里插入图片描述

  • 有时可以省略部分结构,但中括号绝对不能省
    在这里插入图片描述

    int main() {
        [] {
            cout << "func()" << endl;
        }; // 这就是一个lambda表达式,但运行不会打印func()因为这只是个定义,并没有调用
        
        getchar();
        return 0;
    }
    
    int main() {
        ([] {
            cout << "func()" << endl;
        })(); // 这样就调用了,运行后会打印"func()"
        
        getchar();
        return 0;
    }
    

    如何存储呢?

    • lambda表达式本质是个函数,应该使用一个指向函数的指针来存储它取决于右边的函数的返回值是什么

      int main() {
          void (*p)() = [] {
              cout << "func()" << endl;
          }; // 没有返回值所以是void,也可以用auto,反正能自动识别类型
          
          // 调用
          p();
          
          getchar();
          return 0;
      }
      

    稍微复杂一点,实现两个数的相加

    // [capture list] (params list) mutable exception -> return type { function body }
    auto p = [](int a, int b) -> int {
        return a + b;
    };
    cout << p(10, 20) << endl;
    
  • 可以作为函数直接传入

    int exec (int v1, int v2, int(*func)(int, int)) {
        return func(v1, v2);
    }
    int main() {
        cout << exec(v1, v2, [] (int v1, int v2) { return v1 + v2; }) << endl;
    }
    
  • 前面的中括号 -> 变量捕获(值捕获)

    int main() {
        int a = 10;
        int b = 20;
        auto func = [] {
            cout << a << endl;
            cout << b << endl;
        } // 直接访问a和b是不行的,应该在方括号内加入值捕获 [a, b] 
        // 表示外面的a和b要拷贝到lambda表达式内
        auto func = [a, b] {
            cout << a << endl;
            cout << b << endl;
        }    
        auto func = [=] { // 等号表示隐式捕获(值捕获)
            cout << a << endl;
            cout << b << endl;
        } 
    }
    
    • 注意!值捕获和地址捕获

      int main() {
          int a = 10;
          auto func = [a] {
              cout << a << endl;
          };
              
          a = 20;
          func(); // 输出为10
          
          getchar();
          return 0;
      }
      

      默认捕获为值捕获,在捕获的时候a = 10,相当于直接把10传进去。

      那如果想要做到捕获最新的a值怎么办?

      那应该就改成地址捕获

      int main() {
          int a = 10;
          // 地址捕获
          auto func = [&a] {
              cout << a << endl;
          };
          auto func = [&] { // &表示隐式捕获(地址捕获)
              cout << a << endl;
              cout << b << endl;
          }    
          a = 20;
          func(); // 输出为20
          
          getchar();
          return 0;
      }
      
  • mutable

    int main() {
        int a = 10;
        // 如果在lambda里面要改变外面变量的值,应该用地址捕获
        auto func = [&a] {
            a ++;
        };
        func();
        // 用mutable
        // 就算没有参数也要加小括号(格式要求)
        // 并不会改变a的值,因为没有地址捕获
        auto func = [a]() mutable {
            // 相当于在里面又定义了一个int a = 10;
            // int a =
            a ++;
            cout << "lambda =" << a << endl; // lambda = 11;
        };
     
        cout << a << endl; // 10;
        getchar();
        return 0;
    }
    
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
C++ Lambda表达式是一种简洁的匿名表示方法,可以在代码中定义并使用。Lambda表达式的格式一般为:[] (参数列表) mutable -> 返回值类型 { 表达式 }。Lambda表达式可以捕获外部变量,并将其作为参数传递给函数体部分进行处理。Lambda表达式在使用时可以作为函数对象、函数指针或者函数参数进行传递。 Lambda表达式的底层原理是通过生成一个匿名类来实现。该类会重载函数调用运算符(),并包含Lambda表达式的函数体。Lambda表达式中捕获的外部变量会以成员变量的形式存储在该类中。当Lambda表达式被调用时,实际上是调用了该类的重载函数调用运算符()。 Lambda表达式可以与std::function结合使用,以实现函数对象的灵活使用。也可以将Lambda表达式赋值给相同类型的函数指针,实现函数指针的使用。但一般不建议这样使用,因为Lambda表达式已经提供了更加方便和简洁的方式。 总结来说,C++ Lambda表达式是一种用于定义匿名函数的语法,可以捕获外部变量并进行处理。其底层通过生成一个匿名类来实现,并提供了与std::function和函数指针的结合使用方式。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* *2* *3* [C++11:lambda表达式](https://blog.csdn.net/zhang_si_hang/article/details/127117260)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_1"}}] [.reference_item style="max-width: 100%"] [ .reference_list ]

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值