据我了解委托的概念,它们只是指向一个方法。然后当我感到幸运时,我可以出去调用我的代表指向的方法,对吗?
给出以下代码:
class Program
{
static void Main(string[] args)
{
Func<MyClass> myAct = GetAct();
Method(myAct);
}
private static Func<MyClass> GetAct()
{
MyClass obj = new MyClass()
{
Prop1 = 5
};
Func<MyClass> myAct = new Func<MyClass>(
() =>
{
MyClass obj2 = new MyClass();
MyClass2 obj3 = new MyClass2()
{
Prop3 = 25,
Prop4 = "test"
};
obj2.Prop2 = ((obj.Prop1 + 5) * obj3.Prop3)
.ToString() + obj3.Prop4;
return obj2;
});
return myAct;
}
static void Method(Delegate func)
{
GC.Collect();
GC.WaitForPendingFinalizers();
var result = func.DynamicInvoke();
}
}
class MyClass
{
public int Prop1 { get; set; }
public string Prop2 { get; set; }
}
class MyClass2
{
public int Prop3 { get; set; }
public string Prop4 { get; set; }
}
现在我的委托myAct
(在本例中为 a Func<MyClass>
)指向一个匿名函数,该函数执行一些简单的变量分配。到目前为止没有什么特别的。
我们调用委托。
一切都很顺利,正如我们预期的那样。但问题是为什么?如果委托只是简单地指向匿名方法并且垃圾收集已经完成,那么 CLR 怎么知道obj
它的值是什么?obj
调用函数时对存储的引用在哪里?在代表里面?