C++11提供了对匿名函数的支持,称为Lambda函数(也叫Lambda表达式).
[函数对象参数] (操作符重载函数参数)mutable或exception声明 ->返回类型{函数体}
- 代码格式:capture mutable ->return-type {statement}
- [capture]:捕捉列表,捕捉列表总是出现在Lambda函数的开始处,实际上,[]是Lambda引出符,编译器根据该引出符判断接下来的代码是否是Lambda函数,捕捉列表能够捕捉上下文中的变量以供Lambda函数使用。
- (parameters):参数列表,与普通函数的参数列表一致,如果不需要参数传递,则可以连同括号 () 一起省略。
- mutable:mutable修饰符,可以省略。默认情况下,Lambda函数总是一个const函数,mutable可以取消其常量性。在使用该修饰符时,参数列表不可省略(即使参数为空)。
- ->return-type:返回类型,可以省略。用追踪返回类型形式声明函数的返回类型,我们可以在不需要返回值的时候也可以连同符号 -> 一起省略。此外,在返回类型明确的情况下,也可以省略该部分,让编译器对返回类型进行推导。
- {statement}:函数体,内容与普通函数一样,不过除了可以使用参数之外,还可以使用所有捕获的变量。
捕捉列表有以下几种形式:
- [var]表示值传递方式捕捉变量var。
- [=]表示值传递方式捕捉所有父作用域的变量(包括this)。
- [&var]表示引用传递捕捉变量var。
- [&]表示引用传递方式捕捉所有父作用域的变量(包括this)。
- [this]表示值传递方式捕捉当前的this指针。
下面举个例子
MainWindow::MainWindow(QWidget *parent) : QMainWindow(parent) , ui(new Ui::MainWindow) { ui->setupUi(this); //按钮单击不带参数 connect(ui->pushButton, &QPushButton::clicked, [] { qDebug() << "hello lambda"; }); //按钮单击带参数 connect(ui->pushButton, &QPushButton::clicked, [] (bool isCheck) { qDebug() << "hello lambda" << isCheck; }); //自定义信号带参数 connect(this, &MainWindow::sig_test, [] (int i, int j) { qDebug() << "hello lambda" << i << j; }); emit sig_test(5, 8); }