我是靠谱客的博主 聪慧发夹,最近开发中收集的这篇文章主要介绍c++ lambda表达式写在前面reference完,觉得挺不错的,现在分享给大家,希望可以做个参考。

概述

目录

  • 写在前面
  • reference

写在前面

1、本文内容
cpp lambda表达式笔记
2、转载请注明出处:
https://blog.csdn.net/qq_41102371/article/details/124122408

void lambda_prac() {
{
//auto 自动推导返回类型,[]捕获参数,()是传入参数
auto x = [](int val)
{
return val > 3;
};
std::cout << x(5) << std::endl;//1(true)
}
//指定类型
{
//float类型,返回类型double和float 不同,无法自动推导,因此使用->float指定
auto x = [](int val) ->float
{
if (val > 3) {
return 3.0;//double类型
}
else {
return 1.5f;
}
};
std::cout << x(5) << std::endl;
}
//捕获外部变量[y],捕获使用的是值捕获,会在构造的类里面用捕获值去初始化另一个y,值捕获需要加mutable
{
int y = 10;
auto x = [y](int val) mutable
{
++y;
return val > y;
};
std::cout << x(5) << std::endl;
std::cout << y << std::endl;//10,++y只会改变lambda表达式类内部的y,不会改变外部的y
}
//需要在内部修改捕获变量时,使用引用捕获[&y],引用捕获不用加mutable
{
int y = 10;
auto x = [&y](int val)
{
++y;
return val > y;
};
std::cout << x(5) << std::endl;
std::cout << y << std::endl;//11
}
//静态或全局变量不用捕获
{
static int z = 10;
auto x = [](int val)
{
return val > z;
};
std::cout << x(5) << std::endl;
}
//混合捕获
{
int y = 10;
int z = 3;
auto x = [&y,z](int val)
{
++y;
return val > z;
};
std::cout << x(5) << std::endl;
std::cout << y << std::endl;//11
}
//自动捕获,表达式中使用了局部自动对象,这些对象没有显式地出现在捕获列表,使用[=]进行值捕获
{
int y = 10;
int z = 3;
auto x = [=](int val) mutable
{
++y;
return val > z;
};
std::cout << x(5) << std::endl;
std::cout << y << std::endl;//10
}
//同理,引用捕获
{
int y = 10;
int z = 3;
auto x = [&](int val)
{
++y;
return val > z;
};
std::cout << x(5) << std::endl;
std::cout << y << std::endl;//11
}
//[&,z]说明局部自动对象都是采用引用捕获的方式,但z例外,只采用值捕获
//[=,&y]相反
{
int y = 10;
int z = 3;
auto x = [&,z](int val)
{
++y;
return val > z;
};
std::cout << x(5) << std::endl;
std::cout << y << std::endl;//11
}
//*this捕获
{
struct Str {
auto fun() {
int val = 3;
auto lam = [val, this]()
{
return val > x;
};
return lam();
}
int x;//此时x不是局部自动对象,不能直接捕获,要使用this
};
Str s;
s.fun();
}
//初始化捕获,
{
int x = 3;
auto lam = [y = x](int val) {
return val > y;
};
}
//初始化捕获,
{
int x = 3;
int y = 10;
auto lam = [z=x+y](int val) {
return val > z;
};
}
//*this捕获会复制整个对象,更安全,但耗资源
//constexpr 在编译期确定
{
auto lam = [](int val) constexpr
{
return val + 1;
};
constexpr int val = lam(100);//编译期确定val=101
}
//constexpr定义的函数既能在编译期使用也能在运行期调用,consteval只能在编译期调用 c++20
{
auto lam = [](int val) consteval
{
return val + 1;
};
constexpr int val = lam(100);//编译期确定val=101
}
//模板形参 c++20
{
auto lam = []<typename T>(T val)
{
return val + 1;
};
}
}

reference

https://en.cppreference.com/w/

如有错漏,敬请指正
--------------------------------------------------------------------------------------------诺有缸的高飞鸟202204

最后

以上就是聪慧发夹为你收集整理的c++ lambda表达式写在前面reference完的全部内容,希望文章能够帮你解决c++ lambda表达式写在前面reference完所遇到的程序开发问题。

如果觉得靠谱客网站的内容还不错,欢迎将靠谱客网站推荐给程序员好友。

本图文内容来源于网友提供,作为学习参考使用,或来自网络收集整理,版权属于原作者所有。
点赞(33)

评论列表共有 0 条评论

立即
投稿
返回
顶部