是否有可能在C#中知道谁调用了静态属性/访问器?

时间:2013-04-03 22:26:09

标签: c# properties static accessor

我的代码:

public class CLASS_A {    

public static Dictionary<int, CLASS_A> List = new Dictionary<int, CLASS_A>;
public static PP_CLASS pp = null;

 public static CLASS_A ID
 {
  get
  {
   int key = get_threadID;
   if (List.ContainsKey(key))
     return List[key];
   else
     return null;
   }
   set
   {
    int key = get_threadID;
    List[key] = value;
    }
   }

  public virtual void init(lib, name)
  {
    ...
    if (name != "")
    {
      if (pp == null)
       PP = this;
    } 
    ...
  }
}  

所以无论哪个线程调用init,它的id都用于存储它(无论谁调用)。我的列表看起来像这样:

45 = CLASS_A_object0
67 = CLASS_A_object1
...

但是现在当另一个线程在pp上调用一个方法时,比如CLASS_A.pp.setWelcome,这将为pp返回null,并抛出null异常!因为当调用set时,线程id将不同,并且不会在列表中。

那么有可能我知道哪个对象被调用以便我可以进行反向查找吗?或者可能是一个不同的解决方案?

为什么我要这个: 最初我们连接到一台设备,这样就可以了。现在有多个设备,每个设备都有自己的ip /端口。初始代码只有public static PP_CLASS pp = null;所以其他人只是使用类名调用pp上的方法,事情很好。

以前的行为:软件从文件中选择设备列表,因为pp是静态的,它只与第一个设备通信。我在最初的帖子中添加了pp==null行。因此,当代码启动时,pp==null将为真,并且第一个设备已分配,但现在对于其他设备pp==null将为false,因此我无法与其他设备通信。

如果需要更多详细信息,请与我们联系。

2 个答案:

答案 0 :(得分:1)

C# 5.0开始(2012年8月),有一项新功能&#34; Caller Info Attribute&#34;。如果您的类存储在单独的文件中,则可以使用CallerFilePathAttribute来注册实际调用的类。

来自MSDN的示例:

// using System.Runtime.CompilerServices 
// using System.Diagnostics; 

public void DoProcessing()
{
    TraceMessage("Something happened.");
}

public void TraceMessage(string message,
        [CallerMemberName] string memberName = "",
        [CallerFilePath] string sourceFilePath = "",
        [CallerLineNumber] int sourceLineNumber = 0)
{
    Trace.WriteLine("message: " + message);
    Trace.WriteLine("member name: " + memberName);
    Trace.WriteLine("source file path: " + sourceFilePath);
    Trace.WriteLine("source line number: " + sourceLineNumber);
}

// Sample Output: 
//  message: Something happened. 
//  member name: DoProcessing 
//  source file path: c:\Users\username\Documents\Visual Studio 2012\Projects\CallerInfoCS\CallerInfoCS\Form1.cs 
//  source line number: 31

答案 1 :(得分:0)

您可以尝试检查堆栈跟踪。

var trace = new System.Diagnostics.StackTrace();

或仅获取调用行应该是:

var caller = new System.Diagnostics.StackTrace().GetFrame(1)