2013-10-25 64 views
4

我试图将一个方法作为一个动作传递,但似乎该演员并不是每个人都说的。将函数作为参数传递给动作

这是我正在做它:

public class RequestHandler<T> where T : struct 
{ 
    public enum EmployeeRequests { BasicDetails, DependentsAndEmergencyContacts , MedicalHistory } 

    protected Dictionary<T, Action> handlers = new Dictionary<T, Action>(); 

    protected EmployeeManagement empMgmnt = new EmployeeManagement(); 

    public void InitializeHandler(int employeeID) 
    { 

     this.AddHandler(EmployeeRequests.BasicDetails,() => empMgmnt.GetEmployeeBasicDetails(0)); 
    } 

    public void AddHandler(T caseValue, Action action) 
    { 
     handlers.Add(caseValue, action); 
    } 

    public void RemoveHandler(T caseValue) 
    { 
     handlers.Remove(caseValue); 
    } 

    public void ExecuteHandler(T actualValue) 
    { 
     ExecuteHandler(actualValue, Enumerable.Empty<T>()); 
    } 

    public void ExecuteHandler(T actualValue, IEnumerable<T> ensureExistence) 
    { 
     foreach(var val in ensureExistence) 
      if (!handlers.ContainsKey(val)) 
       throw new InvalidOperationException("The case " + val.ToString() + " is not handled."); 
     handlers[actualValue](); 
    } 
} 

这是我的功能,我作为参数传递:

public object GetEmployeeBasicDetails(int employeeID) 
{ 
    return new { First_Name = "Mark", Middle_Initial = "W.", Last_Name = "Rooney"}; 
} 

我收到此错误:

Overloaded method has some invalid arguments.

UPDATE

这是我如何管理来解决这个问题:

public static class RequestHandler 
{ 
    public enum EmployeeRequests { BasicDetails = 0, DependentsAndEmergencyContacts = 1 , MedicalHistory = 2 } 

    private static Dictionary<EmployeeRequests, Func<object>> handlers = new Dictionary<EmployeeRequests, Func<object>>(); 

    public static void InitializeHandler(int employeeID) 
    { 
     Func<object> EmpBasicDetails = delegate { return EmployeeManagement.GetEmployeeBasicDetails(0); }; 
     AddHandler(EmployeeRequests.BasicDetails, EmpBasicDetails); 
    } 

    private static void AddHandler(EmployeeRequests caseValue, Func<object> empBasicAction) 
    { 
     handlers.Add(caseValue, empBasicAction); 
    } 

    public static void RemoveHandler(int caseValue) 
    { 
     var value = (EmployeeRequests)Enum.Parse(typeof(EmployeeRequests), caseValue.ToString()); 
     handlers.Remove(value); 
    } 

    public static object ExecuteHandler(int actualValue) 
    {   
     var request = (EmployeeRequests)Enum.Parse(typeof(EmployeeRequests), actualValue.ToString()); 
     return handlers[(EmployeeRequests)request](); 
    } 
} 
+0

? – SLaks

+0

一个Action特别是具有void返回类型和无参数的方法。您不能将对象返回类型和int参数作为Action来处理您的方法。你试图设置的是一种匹配Func 的方法。 –

+0

您不应该从'GetEmployeeBasicDetails'返回一个匿名对象。请参阅http://stackoverflow.com/questions/1070526/how-to-return-anonymous-type-from-c-sharp-method-that-uses-linq-to-sql –

回答

4

你不能传递一个返回值的方法作为Action,因为Action<T>必须采取参数T和返回任何结果(即void)。

您可以解决此通过传递调用你的方法,而忽略它的输出拉姆达:你在哪里得到的错误

Action empBasicAction =() => GetEmployeeBasicDetails(0); 
+0

这里是一个[演示ideone](http://ideone.com/1KA0iU)。 – dasblinkenlight

+0

好吧,我已经获得了可以工作的代码,但是我想从执行的操作中返回一个对象。类似于object obj = empBasicAction();' – faizanjehangir

+2

@faizanjehangir然后你需要用'Func '替换'Action'。其余的代码将保持不变。 – dasblinkenlight

相关问题