我有一个“通用”样板静态方法,用于检查InvokeRequired并相应地调用相关的操作。
如果操作引发了未处理的异常,则堆栈跟踪没有多大帮助,因为它从此处开始。我可以获得有关控件的信息,但这并不总是有很大帮助。我想知道是否有可能从动作中得到“有用”的东西 - 其他那些'目标'。 (注意,Action通常是lambda或匿名委托......)
public static void Invoke(Control ctrl, Action action)
{
if (ctrl == null)
throw new ArgumentNullException("ctrl");
if (action == null)
return;
var invokeRequired = ctrl.InvokeRequired;
try
{
if (ctrl.InvokeRequired)
ctrl.Invoke(action);
else
action();
}
catch (Exception ex)
{
throw new Exception(String.Format("Invoke error, ctrl={0}, action Target={1}", ctrl.Name, action.Target), ex);
}
}
编辑:根据这个答案,这里是新的重载(也略有改进)
public static void Invoke(Control ctrl, Action action, string context)
{
if (ctrl == null)
throw new ArgumentNullException("ctrl");
if (action == null)
return; //not sure it's worththrowing an exception here...
var invokeRequired = ctrl.InvokeRequired;
try
{
if (invokeRequired)
ctrl.Invoke(action);
else
action();
}
catch (Exception ex)
{
var ps = invokeRequired ? "" : " - has the target control been initialised?";
var errmsg = String.Format("Invoke error, ctrl={0}, action Target={1}, context={2}{3}", ctrl.Name, action.Target, context, ps);
throw new Exception(errmsg, ex);
}
}
答案 0 :(得分:1)
好吧,.Method.Name
将为您提供被调用的方法,但在匿名方法/ lambdas的情况下:不,不是真的。编译器生成的名称相当难以理解,您无法轻松解析委托的IL。您最好的选择可能是包含一个可选的字符串参数(用于指责;如果省略,则使用.Method.Name
)。
答案 1 :(得分:1)
如果我读得正确,您想要访问发生的原始异常的详细信息。您应该能够通过检查ex变量的InnerException属性来获得它。