Es gibt drei Möglichkeiten, Lambda-Ausdrücke externer Variablen in C++ zu erfassen: Erfassung nach Wert: Erstellen Sie eine Kopie der Variablen. Erfassen nach Referenz: Rufen Sie eine Variablenreferenz ab. Gleichzeitige Erfassung nach Wert und Referenz: Ermöglicht die Erfassung mehrerer Variablen, entweder nach Wert oder nach Referenz.
Lambda-Ausdruck ist ein leistungsstarkes Tool in C++, mit dem wir anonyme Funktionen innerhalb von Funktionen definieren können. Manchmal müssen wir in Lambda-Ausdrücken auf externe Variablen zugreifen. In diesem Tutorial werden einige verschiedene Möglichkeiten zum Erfassen externer Variablen behandelt.
Mit der Syntax [var]
können wir die Variable var
nach Wert erfassen. Das bedeutet, dass der Lambda-Ausdruck eine Kopie der Variablen erstellt. [var]
语法,我们可以按值捕获变量 var
。这意味着 lambda 表达式将创建该变量的副本。
auto var = 10; auto lambda = [var] { // 这里可以使用 var return var; };
使用 [&var]
语法,我们可以按引用捕获变量 var
。这意味着 lambda 表达式将获得对变量的引用。
auto var = 10; auto lambda = [&var] { // 这里可以使用 var 并修改它 var++; return var; };
我们可以按值和引用同时捕获多个变量。例如,以下 lambda 表达式按值捕获 val
,按引用捕获 ref
auto func = [](int val, int& ref) { // val 是按值捕获的,ref 是按引用捕获的 };
[&var]
-Syntax können wir die Variable var
durch Referenz erfassen. Das bedeutet, dass der Lambda-Ausdruck einen Verweis auf die Variable erhält. #include <iostream> #include <vector> using namespace std; int main() { // 按值捕获 int num = 10; auto lambda1 = [num] { return num++; }; cout << lambda1() << endl; // 输出 10 // 按引用捕获 vector<int> myVector{1, 2, 3}; auto lambda2 = [&myVector] { myVector.push_back(4); }; lambda2(); for (auto& elem : myVector) { cout << elem << " "; // 输出 1 2 3 4 } cout << endl; return 0; }
val
nach Wert und ref
nach Referenz: 🎜rrreee🎜Ein praktisches Beispiel🎜🎜Das folgende Beispiel zeigt, wie die externe Erfassung nach Wert und verwendet wird per Referenz Variable: 🎜rrreeeDas obige ist der detaillierte Inhalt vonWie erfasst ein C++-Lambda-Ausdruck externe Variablen?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!