在下面的代码中,我将方法B作为要在IterateObjects方法中的对象上执行的操作。
我想问一下我是否可以在参数中显式声明方法,而不是按名称传递它,如下所示:
a.IterateObjects(delegate void(string s){//method body})
它不正确,但我确信我已经看到过类似的工作。您能否提一些建议?谢谢
DelTest a = new DelTest(); //class with method IterateObjects
a.IterateObjects(B) //HERE
private void B(string a)
{
listBox1.Items.Add(a);
}
//another class ....
public void IterateObjects(Action<string> akce)
{
foreach(string a in list)
{
akce(a);
}
}
答案 0 :(得分:3)
是的,您可以像lambda这样使用:
a.IterateObjects ( x => listBox1.Items.Add(x) );
答案 1 :(得分:1)
delegate void MyFunctionDelegate(string a);
public void Main()
{
iterateObjects (delegate(string a){/*do something*/});
}
public void IterateObjects(MyFunctionDelegate akce)
{
foreach(string a in list)
{
akce(a);
}
}
http://msdn.microsoft.com/en-us/library/900fyy8e%28VS.80%29.aspx
就是这样:))
答案 2 :(得分:0)
您可以通过lambda expression在调用时将函数B声明为匿名函数。
答案 3 :(得分:0)
您可以使用lambda表达式:
a.IterateObjects((string s) => listBox1.Items.Add(s))