我的代码:
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,因此我无法与其他设备通信。
如果需要更多详细信息,请与我们联系。
答案 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)