lambda 相关问题

编程语言中的匿名函数或闭包,如Lisp,C#,C ++,Lua,Python,Ruby,JavaScript或Java。 (另外,lambda表达式。)

如何访问超过一种自定义类型深度的属性?

C# 初学者在这里。我有这个: 公开课项目 { 公共 int id { 得到;放; } 公共字符串名称{获取;放; } 公共虚拟 ICollection 属性 { get;放; } { 公开

回答 1 投票 0

捕获此内容并将 lambda 与 fmt::join 结合转发到另一个 lambda

我之前问过这个问题。现在我已将其扩展到以下示例中所示的实际用例(此处有链接): #包括 #包括 #包括 我之前问过这个问题。现在我已将其扩展到以下示例中所示的实际用例(带有链接here): #include <ranges> #include <map> #include <functional> #include <fmt/format.h> #include <iostream> template<typename RANGE, typename LAM> auto foo(RANGE&& range, LAM&& lambda) { return fmt::join(range | std::views::transform( [lam = std::forward<LAM>(lambda)](const auto& element) { return lam(element); }), ","); } class boo { public: int add {2}; void call_foo(){ std::vector<int> d { 2,3,4,5,6}; auto f = fmt::format("{}", foo(d, [this](int i) { std::cout << add << std::endl; return add + i; })); std::cout << f << std::endl; }; }; int main() { std::cout << "HELLO" << std::endl; boo b; b.call_foo(); } 这再次导致std::cout << add << std::endl;处出现段错误。由于它在 fmt::join 内部没有 foo 的情况下工作,我怀疑 fmt::join 不能很好地应对我所得到的。 关于问题是什么以及如何解决的任何想法 那是因为这个坏了: template<typename RANGE, typename LAM> auto foo(RANGE&& range, LAM&& lambda) { return fmt::join(range | std::views::transform( [lam = std::forward<LAM>(lambda)](const auto& element) { return lam(element); }), ","); } C++20(以及之前的 range-v3)具有 view 的广义概念,它不仅仅是迭代器/哨兵对。它也可以有任意状态。对于 views::transform,该状态包括函数对象(当然还有底层的 view)。 问题是,fmt::join - 虽然它看起来像其他系列机械,但实际上并非如此。它只是做这个: template <typename Range> auto join(Range&& range, string_view sep) -> join_view<decltype(detail::adl::adlbegin(range)), decltype(detail::adl::adlend(range))> { return join(detail::adl::adlbegin(range), detail::adl::adlend(range), sep); } 也就是说 - 它只是从范围中取出 begin() 和 end() 并存储它们,扔掉范围的其余部分。 这对于某些范围(特别是借用范围)来说是可以的,但不是全部。具有状态转换的 views::transform(如您此处所示)不是借用的范围 - 您需要在某处保留该可调用对象,而这在这里不会发生。因此出现了问题。 值得注意的是,这只是一个问题,因为views::transform实际上在使用之前就被破坏了。如果您在完整的管道构造中使用 fmt::join ,它会工作得很好: auto f = fmt::format("{}", fmt::join(d | std::views::transform([this](int i) { std::cout << add << std::endl; return add + i; }), ",")); 因为临时 transform 直到完整表达式结束(即所有格式化发生之后)才会被销毁。 一般来说,最好只使用这样的fmt::join。理想情况下,我们只需扩展范围格式说明符以包含分隔符,这样我们就完全不需要 fmt::join。

回答 1 投票 0

如何处理Executor/FutureTask流上的lambda表达式?

这是我的任务类: 公共接口任务回调{ void onTaskCompleted(布尔结果); 无效onTaskFailed(异常e); } 公共类 AsyncTaskExample { 私人最终执行程序exe...

回答 1 投票 0

在C#中获取FieldExpression值

我是 C# 表达式的新手,我正在尝试创建一个从 Expression> 到 SQLWhere 子句的转换器。当提供的表达式如下所示时,我设法做到了这一点

回答 0 投票 0

Java8 中的 BiSupplier

我见过 BiConsumer、BiPredicate、BiFunction,但没有见过 BiSupplier 或类似的。我尝试了下面的代码,但出现了异常: “BiSupplie 中发现多个非重写抽象方法...

回答 3 投票 0

捕获此并将 lambda 转发到另一个 lambda

我遇到了这样的情况:我需要将 lambda 传递到一个自由函数中,该函数将在另一个 lambda 函数中调用此 lambda。我在下面做了一个例子(链接): #包括 #包括 我遇到了需要将 lambda 传递到一个自由函数中的情况,该函数将在另一个 lambda 函数中调用此 lambda。我在下面做了一个例子(link): #include <ranges> #include <map> #include <format> #include <functional> #include <iostream> template<typename RANGE, typename LAM> auto foo(RANGE range, LAM&& lambda) { return range | std::views::transform( [&](const auto& element) { return lambda(element); }); } class boo { public: int add {2}; void call_foo(){ std::vector<int> d { 2,3,4,5,6}; auto f = foo(d, [this](int i) { std::cout << add << std::endl; return add + i; }); std::cout << f[0] << f[1] << std::endl; }; }; int main() { std::cout << "HELLO" << std::endl; boo b; b.call_foo();is no longer valid inside the lambda, } 这里的代码段错误: std::cout << add << std::endl; 这基本上是因为 this 在 lambda 内部变得悬空。但是,我不明白为什么会发生这种情况,以及如何避免这种情况发生。 我也尝试过按值计算 foo 内的 lambda 并移动/前进,但没有得到积极的结果。 不,不是 this 变得悬空,而是 range 和您传递给 foo 的 lambda 一旦 foo 返回就变得悬空。您需要引用 d 并按内部 lambda 中的值获取 lambda: template <typename RANGE, typename LAM> auto foo(RANGE& range, LAM&& lambda) { // ^ return range | std::views::transform( [lambda](const auto& element) { return lambda(element); }); // ^^^^^^ }

回答 1 投票 0

使用 Lambda 连接实体框架 6 中的多个表后获取选定值

我有三个表(此问题的简化示例): 模型是使用 EntityFramework 数据库优先方法生成的。 所有者模型 公共部分类所有者 { 公共所有者() { ...

回答 1 投票 0

递归 Lambda 加入完整的父子层次结构

我想要像图片中最后一列那样的结果(完整层次结构)。 我可以创建多个支撑柱。但我几乎确信可以使用递归 lambda 来做到这一点。 我做了...

回答 1 投票 0

捕获函数指针作为引用会导致段错误

我试图理解为什么以下代码会导致段错误: #包括 #包括 结构体 Foo { Foo() = 默认值; 无效回调1() { std::cout...

回答 1 投票 0

捕获函数指针作为参考

我想了解为什么以下代码会出现段错误: #包括 #包括 结构体 Foo { Foo() = 默认值; 无效回调1() { std::cout &l...

回答 1 投票 0

将 SQL ROW_NUMBER 转换为 Linq 会产生错误的翻译

我有以下 SQL 代码,我想转换为 Entity Framework Core 8 中的 Linq lambda 查询。 从(选择 * SELECT ROW_NUMBER() OVER (PARTITION BY StaffId,[Location] ORDER BY [Timestamp] DE...

回答 1 投票 0

为什么我的 lambda 表达式可以编译,而等效方法引用却不能编译?是仿制药有问题还是我有问题?

我正在尝试将方法引用与泛型类一起使用,并且注意到我可以使其与等效的 lambda 表达式一起使用,但不能与方法引用一起使用。我想知道是否有人可以

回答 1 投票 0

在 Lambda 和 IEnumerable 上使用 Group by 的问题 - ASP.Net

我需要渲染按 CreateDate 分组的事件(游戏)列表 在控制器中我有 公共 ActionResult Index() { var gs = db.Games.Include(p => p.Activity).GroupBy(e => e.CreateDate);...

回答 2 投票 0

Kotlin 中不带大括号的 Lambda 表达式

我们可以使用不带大括号的 lambda 表达式吗?我尝试将 2 个字符串连接成 1 个。 这是代码: 有趣的主(){ println(concat("你好", "世界")) } val concat :(字符串,...

回答 1 投票 0

Google 表格:使用条件函数将一个单元格中的句子分成后续单元格中的多个部分

我想将一个单元格的句子分成同一行中每个包含 4 个单词的单元格。 如果句子超过12个单词,第12个单词应附加“...”,并且不再添加单词。特别

回答 1 投票 0

为什么 max() 在这种情况下返回 7?

l = [7, 9, 5, 6, 13, 5, 15, 3] t = max(l, key=lambda g:g 如果 g%9==1 否则 0) t是l的最大元素,除以9的余数是1。 在本例中,t 等于 7。但此列表不等于

回答 1 投票 0

为什么在 lambda 函数的参数列表中使用 *kwargs.values() 会导致语法错误?

(lambda **kwargs: *kwargs.values())(a=1, b=2) 此代码片段引发 SyntaxError,特别指出“无效语法”,指向参数 lis 中使用 * 运算符...

回答 1 投票 0

这个 Java 构造 `(InputStream is) -> () -> {}`

我不明白我在文档中看到的这个 Java 结构。 public static HttpResponse.BodySubscriber 映射(HttpResponse.BodySubscriber 上游, 功能 我不理解我在此处的文档中看到的 Java 构造。 public static HttpResponse.BodySubscriber 映射(HttpResponse.BodySubscriber 上游, 函数映射器) 我认为我理解但似乎无法复制的部分是示例: public static <W> HttpResponse.BodySubscriber<Supplier<W>> asJSON(Class<W> targetType) { HttpResponse.BodySubscriber<InputStream> upstream = HttpResponse.BodySubscribers.ofInputStream(); HttpResponse.BodySubscriber<Supplier<W>> downstream = HttpResponse.BodySubscribers.mapping( upstream, (InputStream is) -> () -> { try (InputStream stream = is) { ObjectMapper objectMapper = new ObjectMapper(); return objectMapper.readValue(stream, targetType); } catch (IOException e) { throw new UncheckedIOException(e); } } ); return downstream; } 特别是(InputStream is) -> () -> {部分。当我读到它时,我认为它应该是一个 Supplier,它提供了一个 Function 来完成它所做的事情。然而,当我尝试自己编写这样的代码时,它不起作用。 public static void main(String[] args) throws IOException { String r = myMethod((String s)->()->{return s + "ddd";}); } public static String myMethod(Function<String, String> func) { return func.apply("Hello"); } 给我编译错误Target type of a lambda conversion must be an interface。然而,Function是一个接口。 我不明白什么? 这不是一个函数,这是一个函数 这是 lambda 表达式中的 lambda 表达式,您可以通过使用两个 -> 标记来查看它。在您的情况下,inputParam -> resultExpression,在这种情况下,resultExpression 本身是 () -> resultExpression。所以,是的,一个函数 我应该像这样模仿。 public static void main(String[] args) throws IOException { Supplier<String> r = myMethod((String s)->()->{return s + "ddd";}); } public static Supplier<String> myMethod(Function<String, Supplier<String>> func) { return func.apply("Hello"); } 感谢所有评论者。

回答 1 投票 0

相同的 Java SerializedLambda 对 implMethodKind 返回不同的结果

我是 Ronald,JobRunr 的作者。 JobRunr 是一个后台作业调度库,它使用 SerializedLambda 和 ASM 来分析 Java 8 lambda 并将其转换为后台作业。 最近犯了一个错误...

回答 2 投票 0

无法从 lambda 连接到 Redshift

我创建了一个无服务器 Redshift 集群,并希望使用 lambda 从 Redshift 读取/写入数据。 在 lambda 中配置 VPC、子网和安全组 相同的VPC、子网和安全组...

回答 1 投票 0

© www.soinside.com 2019 - 2024. All rights reserved.