c# - 如何在 C# 中获取有关委托(delegate)函数实例的信息(如名称或包含类)?

标签 c# delegates

我有一个委托(delegate)函数

class FuncActivator {
  public delegate void DelFunc(string arg, string val);
}

我保留该函数的实例,以便稍后在程序中同时启动(也在 FuncActivator 中:

List<DelFunc> funcList = new List<DelFunc>();

public void KeepFunc(DelFunc delFunc) {
  funcList.Add(delFunc);
}

现在我想获取有关实际委托(delegate)名称的信息,或者至少是哪个类在此处传递的信息。比如在不同的类(class)

public class FunnyClass {
  public void FunnyFunc(string arg, string val) {
    //..Do stuff
  }

  public FunnyClass () {
    FuncActivatorInstance.KeepFunc(FunnyFunc);
  }
}

我想通过 FuncActivator 中的方法列出我列表中所有委托(delegate)的名称或调用者(例如“FunnyFunc”或至少是“FunnyClass”)。 这可能吗?

最佳答案

这段代码:

public void PrintFuncs()
{
    foreach (var func in funcList)
    {
        Console.WriteLine(func.Method.Name);
        Console.WriteLine(func.Method.DeclaringType.Name);
    }
}

打印:

FunnyFunc
FunnyClass

将自身添加到列表中的 FunnyClass 实例位于 func.Target,如果您也想使用它的话。

附加的 Lambda 表达式,因为它们是匿名的,将有一个自动生成的方法名称。如果也为它生成了一个类,它也会有一个自动生成的名称。所以仅供引用,您不会总是能够从中获得非常可读的字符串。

关于c# - 如何在 C# 中获取有关委托(delegate)函数实例的信息(如名称或包含类)?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/11394371/

相关文章:

c# - 转换数据类型并将其用作 TestContext.DataRow 的扩展方法

c# - System.Data.OracleClient 与。 ODP.NET

c# - 带有 Entity Framework 的复合键表的 SqlException 'invalid column name'

c# - 从 C# 调用 c 函数

c# - 使用 "this"引用匿名委托(delegate)

objective-c - MacRuby:遵守协议(protocol)

C# RegEx 没有返回它应该返回的内容

c# - 委托(delegate)中的异常处理

.net - 一个空的委托(delegate)会吃掉内存吗?

c# - 将可变参数传递给委托(delegate)