天天看點

C++Lambda表達式

概述

C++ 11 中的 Lambda 表達式用于定義并建立匿名的函數對象,以簡化程式設計工作。

Lambda

的文法形式如下:

[捕獲清單] (參數) mutable 或 exception 聲明 -> 傳回值類型 {函數體}

//計算兩個值的和
auto func = [](int a, int b) -> int{return a+b;};
//當傳回值的類型是确定時,可以忽略傳回值
auto func = [](int a, int b){return a + b;};
//調用
int sum = func(1, 3);
           

文法分析

捕獲清單

Lambda 表達式相當于一個類,那麼捕獲清單就是傳遞給這個類的類成員。比如:

class Labmda
{
public:
    const int test;
    Labmda(int value):test(value)
    {
    }
public:
    int run(int a, int b)
    {
        return a + b + test;
    }
}

int main()
{
    int test = 10;
    auto func = Labmda(test);
    int sum = func.run(1, 3);
}

//使用Lambda 表達式的寫法
int main()
{
    int test = 10;
    auto func = [test](int a, int b){return a + b + test;};
    int sum = func(1, 3);
}
           

捕獲清單有以下格式:

格式 描述
[] 不帶任何參數
[=] Lambda表達式之前的局部變量,包括所在類的this,變量按值方式傳遞
[&] Lambda表達式之前的局部變量,包括所在類的this,變量按引用方式傳遞
[this] Lambda表達式所在類的this
[a] Lambda表達式之前的局部變量a的值,也可以傳入多個值,如

[a , b]

[&a] Lambda表達式之前的局部變量a的引用

關鍵字聲明

關鍵字聲明一般都很少用到,也不建議随便使用,可以忽略不計。

mutable

當捕獲清單以值的方式傳遞時有效,加上此關鍵字後,可以修改Lambda類成員(帶const修飾符)。比如:

int test = 10;
//編譯報錯,test成員不能修改
auto func = [test](int a, int b){test = 8; return a + b + test;}; 
//編譯正常
auto func = [test](int a, int b)mutable {test = 8; return a + b + test;}; 
           

這裡需要注意的是:Lambda類成員

test

修改之後,并不會改變外部

int test

的值。

exception

exception 聲明用于指定函數抛出的異常,如抛出整數類型的異常,可以使用 throw(int)

示例

捕獲清單按值傳遞

int test = 10;
auto func = [=](int a, int b){return a + b + test;};
auto func2 = [test](int a, int b){return a + b + test;};
int sum = func(1, 3); //sum等于14
           

這裡需要注意的是

func

表達式中

test

的值隻更新到表達式之前:

int test = 10;
auto func = [=](int a, int b){return a + b + test;};
test = 5;
int sum = func(1, 3); //sum還是等于14
           

捕獲清單按引用傳遞

int test = 10;
auto func = [&](int a, int b){test = 5; return a + b + test;};
auto func2 = [&test](int a, int b){test = 5; return a + b + test;};
int sum = func(1, 3); //sum等于9,test等于5
           

這裡

func

test

的值就能随時更新:

int test = 10;
auto func = [&](int a, int b){return a + b + test;};
test = 5;
int sum = func(1, 3); //sum等于9,test等于5
           

繼續閱讀