Я знаю, что в php вы можете сделать звонок как:
$function_name = 'hello';
$function_name();
function hello() { echo 'hello'; }
Возможно ли это в .Net?
Я знаю, что в php вы можете сделать звонок как:
$function_name = 'hello';
$function_name();
function hello() { echo 'hello'; }
Возможно ли это в .Net?
Ответы:
Да. Вы можете использовать отражение. Что-то вроде этого:
Type thisType = this.GetType();
MethodInfo theMethod = thisType.GetMethod(TheCommandString);
theMethod.Invoke(this, userParameters);
Type thisType = this.GetType(); MethodInfo theMethod = thisType.GetMethod(TheCommandString, BindingFlags.NonPublic | BindingFlags.Instance); theMethod.Invoke(this, userParameters);
Вы можете вызывать методы экземпляра класса, используя отражение, делая динамический вызов метода:
Предположим, что у вас есть метод hello в фактическом экземпляре (this):
string methodName = "hello";
//Get the method information using the method info class
MethodInfo mi = this.GetType().GetMethod(methodName);
//Invoke the method
// (null- no parameter for the method call
// or you can pass the array of parameters...)
mi.Invoke(this, null);
class Program
{
static void Main(string[] args)
{
Type type = typeof(MyReflectionClass);
MethodInfo method = type.GetMethod("MyMethod");
MyReflectionClass c = new MyReflectionClass();
string result = (string)method.Invoke(c, null);
Console.WriteLine(result);
}
}
public class MyReflectionClass
{
public string MyMethod()
{
return DateTime.Now.ToString();
}
}
Небольшая касательная - если вы хотите проанализировать и оценить всю строку выражения, которая содержит (вложенные!) Функции, рассмотрите NCalc ( http://ncalc.codeplex.com/ и nuget)
Ex. немного изменен из проектной документации:
// the expression to evaluate, e.g. from user input (like a calculator program, hint hint college students)
var exprStr = "10 + MyFunction(3, 6)";
Expression e = new Expression(exprString);
// tell it how to handle your custom function
e.EvaluateFunction += delegate(string name, FunctionArgs args) {
if (name == "MyFunction")
args.Result = (int)args.Parameters[0].Evaluate() + (int)args.Parameters[1].Evaluate();
};
// confirm it worked
Debug.Assert(19 == e.Evaluate());
А внутри EvaluateFunction
делегата вы бы назвали свою существующую функцию.
Фактически я работаю над Windows Workflow 4.5, и мне удалось найти способ передать делегат из машины состояний в метод безуспешно. Единственный способ найти меня - это передать строку с именем метода, который я хотел передать как делегат, и преобразовать строку в делегат внутри метода. Очень хороший ответ. Спасибо. Проверьте эту ссылку https://msdn.microsoft.com/en-us/library/53cz7sc6(v=vs.110).aspx
class Program
{
static void Main(string[] args)
{
string method = args[0]; // get name method
CallMethod(method);
}
public static void CallMethod(string method)
{
try
{
Type type = typeof(Program);
MethodInfo methodInfo = type.GetMethod(method);
methodInfo.Invoke(method, null);
}
catch(Exception ex)
{
Console.WriteLine("Error: " + ex.Message);
Console.ReadKey();
}
}
public static void Hello()
{
string a = "hello world!";
Console.WriteLine(a);
Console.ReadKey();
}
}
В C # вы можете создавать делегаты как указатели на функции. Проверьте следующую статью MSDN для получения информации об использовании:http://msdn.microsoft.com/en-us/library/ms173171(VS.80).aspx
public static void hello()
{
Console.Write("hello world");
}
/* code snipped */
public delegate void functionPointer();
functionPointer foo = hello;
foo(); // Writes hello world to the console.
public
также.