• Lambda表达式


    Lambda表达式基本语法如下:

    [捕获列表](参数列表)mutable(可选)异常属性->返回类型

    {

    //函数体

    }

    所谓捕获列表,其实可以理解为参数的一种类型,Lambda表达式内部函数体在默认情况下是不能够使用函数体外部的变量的,这时候捕获列表可以起到传递外部数据的作用。

    捕获列表也分为一下几种:

    1.值捕获

    与参数传值类似,值捕获的前提是变量可以拷贝,不同之处则在于,被捕获的变量在Lambda表达式被创建时拷贝,而非调用时拷贝

    #include <iostream>
    using namespace std;
    
    int main()
    {
       int value = 1;
       auto copy_value = [value]{
          return value;
       };
    
       value = 100;
       auto stored_value = copy_value();
       std::cout << "stored_value = " << stored_value << std::endl;
    
       return 0;
    }

    2.引用捕获

    与引用传参类似,引用捕获保存的是引用,值会发生变化

    #include <iostream>
    using namespace std;
    
    int main()
    {
       int value = 1;
       auto copy_value = [&value]{
          return value;
       };
    
       value = 100;
       auto stored_value = copy_value();
       std::cout << "stored_value = " << stored_value << std::endl;
    
       return 0;
    }

    3.隐式捕获

    手动书写捕获列表有时候是非常复杂的,这种机械性的工作可以交给编译器来处理,这时候可以在捕获列表写一个&或=向编译器声明采用引用捕获或者值捕获

    捕获列表最常用的四种形式:

    • []空捕获列表
    • [name1, name2, ...]捕获一系列变量
    • [&]引用捕获,让编译器自行推导引用列表
    • [=]值捕获,让编译器自行推导值捕获列表
  • 相关阅读:
    移动端的爬坑路
    判断设备ios或android以及判断是否是微信内置浏览器
    使用vue directive 写好的滑动删除功能
    不用ajax,使用json数据渲染商品的方法
    vue中使用swiper的一些坑
    vue的自定义指令的坑
    better-score获取滑动距离的坑
    linux命令
    关于打印
    数据可视化
  • 原文地址:https://www.cnblogs.com/aelite/p/15906574.html
Copyright © 2020-2023  润新知