Get parameter name
How do you get the method NAME parameter . The examples show how to get parameter values , but not NAMES . I want to see parma = 99, parmb = 1. Not only 99, 1.
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Threading.Tasks;
using System.Diagnostics;
using PostSharp.Aspects;
namespace GettingParmNames
{
public class Program
{
static void Main(string[] args)
{
Foo myfoo = new Foo();
int sum = myfoo.DoA(99, 1);
Console.WriteLine(sum.ToString());
Console.ReadKey();
}
}
public class Foo
{
[ExceptionAspect]
public int DoA(int parma, int parmb)
{
int retVal;
try
{
retVal = parma + parmb;
if (parma == 99)
{
throw new Exception("Fake Exception");
}
}
catch (Exception ex)
{
retVal = -1;
throw new Exception("There was a problem");
}
return retVal;
}
}
[Serializable]
public class ExceptionAspect : OnExceptionAspect
{
public override void OnException(MethodExecutionArgs args)
{
string parameterValues = "";
foreach (object arg in args.Arguments)
{
if (parameterValues.Length > 0)
{
parameterValues += ", ";
}
if (arg != null)
{
parameterValues += arg.ToString();
}
else
{
parameterValues += "null";
}
}
Console.WriteLine("Exception {0} in {1}.{2} invoked with arguments {3}", args.Exception.GetType().Name, args.Method.DeclaringType.FullName, args.Method.Name, parameterValues );
}
}
}
+3
source to share
1 answer
You can access method parameter information in your method OnException
by calling args.Method.GetParameters()
. But it is usually better to initialize data at compile time for performance reasons - override in CompileTimeInitialize .
[Serializable]
public class ExceptionAspect : OnExceptionAspect
{
private string[] parameterNames;
public override void CompileTimeInitialize(MethodBase method, AspectInfo aspectInfo)
{
parameterNames = method.GetParameters().Select(p => p.Name).ToArray();
}
public override void OnException(MethodExecutionArgs args)
{
StringBuilder parameterValues = new StringBuilder();
for (int i = 0; i < args.Arguments.Count; i++)
{
if ( parameterValues.Length > 0 )
{
parameterValues.Append(", ");
}
parameterValues.AppendFormat(
"{0} = {1}", parameterNames[i], args.Arguments[i] ?? "null");
}
// ...
}
+4
source to share