C++使用Lambda表達(dá)式實(shí)例講解
C++ 中的 Lambda 表達(dá)式是一種匿名函數(shù),可以方便地創(chuàng)建并傳遞函數(shù)對(duì)象。這是 C++11 引入的一項(xiàng)重要功能,可以大大提高代碼的可讀性和簡(jiǎn)潔性。
以下是一個(gè)深入講解 C++ 使用 Lambda 表達(dá)式的例子,包括基本語(yǔ)法、捕獲列表、函數(shù)調(diào)用、以及與 STL 的結(jié)合使用等。
Lambda基本語(yǔ)法
首先,我們來(lái)看一個(gè)最簡(jiǎn)單的 lambda 表達(dá)式:
[](){/* do nothing */};
這個(gè) lambda 表達(dá)式定義了一個(gè)空函數(shù),沒(méi)有參數(shù),也沒(méi)有返回值。你可以將其看作是一個(gè)沒(méi)有實(shí)體的具名函數(shù)。
你還可以定義帶有參數(shù)的 lambda 表達(dá)式:
[](int a, float b){return a + b;};
這個(gè)函數(shù)接收兩個(gè)參數(shù),一個(gè)是 int 類型的 a,另一個(gè)是 float 類型的 b。它的返回值是 a 和 b 的和。
你也可以定義帶有默認(rèn)參數(shù)的 lambda 表達(dá)式:
[](int a, float b = 0.0f){return a + b;};
這個(gè)函數(shù)和上一個(gè)函數(shù)功能基本相同,只是 b 參數(shù)的默認(rèn)值是 0.0f。
Lambda的捕獲列表
你還可以在 lambda 表達(dá)式中捕獲外部變量的值:
int a = 10;
float b = 20.0f;
auto add = [&a, &b]() { return a + b; }; // 使用引用捕獲外部變量
std::cout << add() << std::endl; // 輸出 30
在這個(gè)例子中,&a 和 &b 是通過(guò)引用來(lái)捕獲 a 和 b 的值的。這意味著 lambda 表達(dá)式可以修改捕獲的變量的值。如果你只想在 lambda 表達(dá)式中使用外部變量的值,而不修改它們的值,你應(yīng)該使用值捕獲而不是引用捕獲。例如:
int a = 10;
float b = 20.0f;
auto add = [a, b]() { return a + b; }; // 使用值捕獲外部變量
std::cout << add() << std::endl; // 輸出 30
在這個(gè)例子中,雖然 a 和 b 的值被傳遞給了 lambda 表達(dá)式,但是 lambda 表達(dá)式并不能修改它們的值。
Lambda與函數(shù)調(diào)用
你可以將 lambda 表達(dá)式作為一個(gè)函數(shù)參數(shù)傳遞給其他函數(shù)。例如,你可以使用一個(gè) lambda 表達(dá)式來(lái)作為 std::sort 函數(shù)的比較函數(shù):
std::vector<int> v = {5, 3, 1, 4, 2};
std::sort(v.begin(), v.end(), [](int a, int b) {return a < b;}); // 使用 lambda 表達(dá)式作為比較函數(shù)
std::copy(v.begin(), v.end(), std::ostream_iterator<int>(std::cout, " ")); std::cout << std::endl; // 輸出 1 2 3 4 5
在這個(gè)例子中,lambda 表達(dá)式 [](int a, int b) {return a < b;} 被傳遞給了 std::sort 函數(shù),用于比較 v 中的元素。這意味著你可以用 lambda 表達(dá)式來(lái)實(shí)現(xiàn)自定義的算法和數(shù)據(jù)結(jié)構(gòu)。
Lambda與 STL 的結(jié)合使用
下面我們?cè)賮?lái)看一個(gè)比較復(fù)雜但很有用的例子:使用 lambda 表達(dá)式和 STL 來(lái)查找一個(gè) vector 中第一個(gè)出現(xiàn)的不重復(fù)的元素:
#include <iostream>
#include <vector>
#include <algorithm>
#include <unordered_set>
int main() {
std::vector<int> v = {1, 2, 3, 2, 4, 3, 5, 6, 4};
auto it = std::find_if(v.begin(), v.end(), [&](int a) {
return std::find(std::begin(un), std::end(un), a) == std::end(un);
});
}
在這個(gè)例子中,我們使用了一個(gè)較為復(fù)雜的 lambda 表達(dá)式來(lái)作為 std::find_if 函數(shù)的比較函數(shù)。這個(gè) lambda 表達(dá)式接收一個(gè)參數(shù) a,然后使用一個(gè)名為 un 的 std::unordered_set 來(lái)查找 a 是否第一次出現(xiàn)。這個(gè)例子展示了如何使用 lambda 表達(dá)式和 STL 來(lái)解決一個(gè)復(fù)雜的問(wèn)題。