1

我最近自己探索了 c#。但被这个问题困住了。

所以我有一个方法 dbExec

public void dbExec(Action<OleDbCommand> func)
{
    using (var conn = new OleDbConnection(connStr))
    {
        conn.Open();
        var cmd = conn.CreateCommand();
        func(cmd); 
    }
}

代表,

public delegate void DelCmd(OleDbCommand cmd);

和另一种方法:

public ICollection<string> CheckUserPermissions() 
{
    List<string> logins = new List<string>();
    DelCmd delCmd = delegate(OleDbCommand cmd)
    {
        cmd.CommandText = "SELECT PERMISSIONS.LOGIN FROM PERMISSIONS";
        using (var rdr = cmd.ExecuteReader()) while (rdr.Read()) logins.Add(rdr["LOGIN"].ToString());  
    };
    dbExec(delcmd);
    return logins;
} 

声明的问题dbExec(delcmd);。错误是“delcmd 在当前上下文中不存在”。如何将匿名方法作为参数传递给具有 Action 声明参数的另一个方法?

4

2 回答 2

4

您也可以完全避免定义委托。

像这样:

public ICollection<string> CheckUserPermissions()
{
    List<string> logins = new List<string>();

    Action<OleDbCommand> delCmd = cmd => 
    {
        cmd.CommandText = "SELECT PERMISSIONS.LOGIN FROM PERMISSIONS";
        using (var rdr = cmd.ExecuteReader()) 
            while (rdr.Read()) logins.Add(rdr["LOGIN"].ToString());
    };
    dbExec(delCmd);
    return logins;
}

编辑:我实际上是指Servy在另一个答案的评论中写的,但他描述得更好。

于 2013-10-04T13:59:20.993 回答
1

你有一个错字 - 它应该是delCmd而不是delcmd. C# 是区分大小写的语言

更新:DelCmd不一样Action<OleDbCommand>- 那是不同的类型,你甚至不能将代表相互转换。但是您可以创建新的操作委托:

dbExec(new Action<OleDbCommand>(delCmd));
于 2013-10-04T13:29:18.937 回答