我已经为日志库创建了包装器,我想在其中记录抛出异常的外部方法的参数:
public void MethodA(string param1, int param2)
{
try
{
throw new Exception();
}
catch(Exception ex)
{
Logger.Error(ex);
}
}
...
public static void Error(Exception ex)
{
...
}
正如您所看到的,我想获取有关错误方法级别的 MethodA 信息。我会非常乐意使用:
ParameterInfo[] pi = new StackFrame(1).GetMethod().GetParameters();
因为它拥有一切,但我刚刚阅读了多篇关于性能不佳的帖子。在我看来,也许这不是最好的方法(另一方面,我们正在讨论异常处理 - 此时它已经不太重要)。但是,我找不到使用反射的传统方法来解决这个问题。也许有人可以启发我?
或者也许您仍然会选择 StackFrame 解决方案?
它是对超性能的要求相当小的 asp.net 应用程序。
编辑1:
也许我不太确定我想写什么。我正在使用 StackFrame 解决方案,即使它可能需要长达 20 毫秒才能获取帧,但我真的很好奇如何通过反射获得类似的结果。
您可能会发现我的这个实用方法很有用,因为它还解决了您可能遇到的另一个问题:当您想从构造函数中获取当前堆栈帧时,事情有点奇怪。
using Collections = MikeNakis.Abstract.Collections;
using Diagnostics = System.Diagnostics;
using Generic = System.Collections.Generic;
using Reflection = System.Reflection;
[...]
///<summary>Collect stack frames</summary>
///<param name="frames_to_skip">Number of frames to skip (usually 1)</param>
///<param name="type">When invoking from within a constructor, specify the type of the containing class so as to
///skip any other constructors.</param>
public static Generic.IList<Diagnostics.StackFrame> CollectStackframes( int frames_to_skip, System.Type type = null )
{
var frames = new Diagnostics.StackTrace( frames_to_skip + 1, fNeedFileInfo:true ).GetFrames();
int i = 0;
if( type != null )
{
for( ; i < frames.Length; i++ )
{
Reflection.MethodBase method = frames[i].GetMethod();
if( !method.IsConstructor )
break;
//Does not work: if( method.DeclaringType == type )
//Does not work: if( Equals( method.DeclaringType, type ) )
//Does not work: if( Equals( method.DeclaringType.TypeHandle, type.TypeHandle ) )
if( Equals( method.DeclaringType.GUID, type.GUID ) )
{
i++;
break;
}
}
}
var list_of_frame = new Generic.List<Diagnostics.StackFrame>( frames.Length - i );
for( ; i < frames.Length; i++ )
list_of_frame.Add( frames[i] );
return Collections.Util.NewListReadonly( list_of_frame );
}
(Note: Collections.Util.NewListReadonly()
是我的一个静态实用方法,它创建一个只读列表并返回其IList<T>
界面。)
不知道性能如何new Diagnostics.StackTrace()
:我猜它和使用反射一样慢(它可能算作反射),但可能比抛出异常快一点。
不过,我会让你对参数部分感到失望:我找不到在运行时获取方法参数内容的方法。因此,您希望获得的只是参数的类型和名称,而不是它们的值。如果您找到方法,请告诉我。
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)