- r - 以节省内存的方式增长 data.frame
- ruby-on-rails - ruby/ruby on rails 内存泄漏检测
- android - 无法解析导入android.support.v7.app
- UNIX 域套接字与共享内存(映射文件)
我正在回答 question关于闭包(合法地)延长对象生命周期的可能性,当我遇到一些非常好奇的 C# 编译器代码生成(如果重要的话是 4.0)。
我能找到的最短的重现如下:
结果:编译器创建一个引用创建 lambda 的对象的闭包对象,但它没有理由这样做 - 委托(delegate)的“内部”目标是一个静态方法,并且执行委托(delegate)时,不需要(也不会)触及 lambda-creating-object 的实例成员。实际上,编译器就像程序员捕获了 this
一样。没有理由。
class Foo
{
private Action _field;
public void InstanceMethod()
{
var capturedVariable = Math.Pow(42, 1);
_field = () => StaticMethod(capturedVariable);
}
private static void StaticMethod(double arg) { }
}
发布版本生成的代码(反编译为“更简单的”C#)如下所示:
public void InstanceMethod()
{
<>c__DisplayClass1 CS$<>8__locals2 = new <>c__DisplayClass1();
CS$<>8__locals2.<>4__this = this; // What's this doing here?
CS$<>8__locals2.capturedVariable = Math.Pow(42.0, 1.0);
this._field = new Action(CS$<>8__locals2.<InstanceMethod>b__0);
}
[CompilerGenerated]
private sealed class <>c__DisplayClass1
{
// Fields
public Foo <>4__this; // Never read, only written to.
public double capturedVariable;
// Methods
public void <InstanceMethod>b__0()
{
Foo.StaticMethod(this.capturedVariable);
}
}
观察 <>4__this
闭包对象的字段填充了一个对象引用,但从未被读取(没有原因)。
那么这里发生了什么?语言规范允许吗?这是一个编译器错误/奇怪还是有一个很好的理由(我显然没有)让闭包引用该对象?这让我很焦虑,因为这看起来像是喜欢闭包的程序员(比如我)无意中将奇怪的内存泄漏(想象一下如果委托(delegate)被用作事件处理程序)引入程序的秘诀。
最佳答案
这确实看起来像一个错误。谢谢你让我注意到它。我会调查一下。可能已经找到并修复了。
关于c# - 这个 object-lifetime-extending-closure 是 C# 编译器错误吗?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/8419079/
我是Rust的初学者,无法编译以下代码。我知道这个问题可能并不新鲜,请尝试在各处搜索,但找不到以下问题的正确答案。 基本上,我试图从线程中调用方法,并且还使用不同的结构在线程之间发送和接收对象。 us
我的 lib.rs 中有以下结构 pub enum ConfigurationSource { StringContent(String), FileContent(PathBuf)
我有一个 trait Surface: 'static我想为 struct Obj 实现.特征需要是 'static因为我想存储 Surface 类型的对象在Vec> . 第一步我试过这个。 impl
我试图在可迭代序列中找到重复项。此外,我想知道到那时为止该序列中出现的元素。 我创建了一个 HashMap 并尝试从 take_while 使用的闭包中对其调用 insert。但是,由于与具体/绑定(
trait BT { fn get_a(&self) -> &A; } #[derive(Debug)] struct A { v: i32, } impl A { fn nb
在编写代码以适应 Rust 时,我偶然发现了一个编译器错误。我想了解为什么会收到错误以及如何处理: cannot infer an appropriate lifetime for lifetime
我试图了解 owned 的生命周期类,在用户定义的迭代器中使用时。考虑以下代码: var a = new owned C(); var b = new owned C(); a.i = 2; fora
我正在使用async-tungstenite来监听websocket,并使用async-std的StreamExt对结果流进行操作。 我想使用HashMap从websocket累积最新的股票行情指示器
我正在创建一个类似于映射的数据结构,其中每个值都提供了一种通过实现特征来检索其唯一键的方法。当临时创建关键字以例如在映射中查找值时,期望关键字引用相应值的一个或多个字段(或者仅引用堆栈数据等)。显然,
我正在创建一个类似于映射的数据结构,其中每个值都提供了一种通过实现特征来检索其唯一键的方法。当临时创建关键字以例如在映射中查找值时,期望关键字引用相应值的一个或多个字段(或者仅引用堆栈数据等)。显然,
我正在创建一个类似于映射的数据结构,其中每个值都提供了一种通过实现特征来检索其唯一键的方法。当临时创建关键字以例如在映射中查找值时,期望关键字引用相应值的一个或多个字段(或者仅引用堆栈数据等)。显然,
我想实现一个类似于调试 builders 的构建器由标准库定义。它们使用如下结构定义: struct DebugFoo { fmt: &'a mut std::fmt::Formatter }
我有点难过。我希望通过以下代码。 enum Source { String(&'self str), ReaderUtil(&'self ReaderUtil) } pub struc
我正在尝试获取 Windows 中耗时(以毫秒为单位)。我发现这样做的唯一方法是使用 FILETIME 结构获取自 1601 年以来的 100 纳秒数。但是 FILETIME 结构将值存储在两个变量中
对于 CakePHP 商店应用程序,我需要 365 天的 cookie 生命周期。该应用程序在使用 CentOS 7 和 Plesk 18.0.30、PHP 7.3 FPM 的托管 vServer 上
我最近遇到了一条我从未见过的借用检查器消息,我试图理解它。这是重现它的代码(简化的,现实生活中的例子更复杂)- playground : fn foo(v1: &mut Vec, v2: &mut V
据我所知,当我订阅铁路由器钩子(Hook)内的结果集时,如之前:或 waitOn:,它工作正常,但一旦另一条路线运行,它似乎就被拆除了。有谁知道这是否会发生? 假设是这样,这是否意味着使订阅在路由之间
我正在尝试将 str 转换为 Reader,但失败了。 下面的代码所做的是使用 with_str_reader 从 str 中提取 Reader use std::io::{with_str_read
当 a PayPal subscription is created 时,批准 URL 在响应中可用。 看起来像这样,包括一个 token : https://www.sandbox.paypal.c
在basic.life C++ 标准的一部分,可以找到以下内容(强调我的): The lifetime of an object o of type T ends when: if T is a cl
我是一名优秀的程序员,十分优秀!