lambda表达式
lambda基本结构如下:
[ 捕获 ] ( 形参 ) -> ret { 函数体 };
lambda表达式一般都是以方括号[]开头,有参数就使用(),无参就直接省略()即可,最后结束于{},其中的ret表示返回类型(可以不写会自动识别,建议写上,增加可读性)。
举一个简单的例子,定义一个lambda表达式,如下:
auto at=[](vector<int> &v1, vector<int> &v2) -> bool {
return v1[1] > v2[1] || (v1[1] == v2[1] && v1[0] > v2[0]);
};
v1
和v2
为形参;bool
为返回类型;v1[1] > v2[1] || (v1[1] == v2[1] && v1[0] > v2[0])
函数体实现。
捕获与传参示例
采用复制捕获的形式,举一个例子:
auto lambAdd = [x](int a) { return a + x;};
通过该函数,实现捕获的数值x
与传值a
的求和。
捕获与传参区别
通过以上的例子,不难发现,捕获与传参数很像。查找相关资源,最后在大神的博文c++中lambda表达式用法中有了初步理解,特在此做一下记录。
假设:一个公司有99名员工,每个员工的工号是从1~99,我们现在想找出工号是8的整数倍的所有员工,代码如下:
int main()
{
int x = 8;
auto t = [x](int i){
if ( i % x == 0 )
{
std::cout << "value is " << i << std::endl;
}
};
auto t2 = [](int i, int x){
if ( i % x == 0 )
{
std::cout << "value is " << i << std::endl;
}
};
for(int j = 1; j< 100; j++)
{
t(j);
t2(j, x);
}
}
表达式t使用了捕获,而表达式t2没有使用捕获,从代码作用和量来看,它们其实区别不大,但有一点,对于表达式t,x的值只复制了一次,而对于t2表达式,每次调用都要生成一个临时变量来存放x的值,这其实是多了时间和空间的开销。