我有一种情况,我将方法名称作为字符串传递给函数,但我不希望它硬编码。 例如
void MyMethodName()
{
// some code
}
void SomeOtherMethod()
{
SomeExternalLibrary.ExternalClass.FunctionWithStringParameter("MyMethodName");
}
我想要这样的事情:
FunctionWithStringParameter(MyMethodName.ToString());
这样我可以通过“查找所有引用”跟踪方法调用,并且可以毫无后顾之忧地使用重构。
答案 0 :(得分:5)
也许最简单的方法是提供一个可以将委托作为参数的重载FunctionWithStringParameter
。
重载可能很简单:
void FunctionWithStringParameter(Action d)
{
FunctionWithStringParameter(d.Method.Name);
}
并称之为:
FunctionWithStringParameter(MyMethodName);
要接受具有不同签名的方法,您必须提供许多不同的重载,或接受Delegate
作为参数,如下所示:
void FunctionWithStringParameter(Delegate d)
{
FunctionWithStringParameter(d.Method.Name);
}
不幸的是,如果你这样做,你必须通过指定委托类型来调用它:
FunctionWithStringParameter((Action)MyMethodName);
答案 1 :(得分:2)
这些天使用的一种技术是通过Expression
。
FunctionWithStringParameter(x => MyMethodName(x));
在你的方法中你可以选择表达式来获取方法名称(并检查它是一个简单的方法调用表达式)。
有关如何拆分lambda表达式的建议,请参阅Retrieving Property name from lambda expression。
答案 2 :(得分:0)
我不确定你要做什么,但是在引用方法和属性时避免“魔术字符串”的一种方法是做ASP.NET MVC Helpers方法看起来像这样:
@Html.TextBoxFor(m=> m.SomeProperty)
并做一些允许你这样做的帮助:
string methodName = ReflectionHelper.MethodNameFor<TheTypeWIthTheMethod>(x=> x.TheMethod())
实现看起来像这样:
static string MethodNameFor<T>(Expression<Action<T>> expression)
{
return ((MethodCallExpression)expression.Body).Method.Name;
}