我正在从网上学习C#,在练习参数数组作为参数和代理人并且玩弄时,我想出了一段死路或者我不知道如何做的代码。
(我不是想写任何东西,也不是为了什么,我只是在研究和写作:))
是否可以将存储在列表中的方法传递给Delegate然后调用?
(ps:plz忽略了我将静态输出,它不会像这样运行(或永远不会)的事实)
delegate void one();
delegate void two();
delegate void three();
one Del01 = new one(d1);
two Del02 = new two(d2);
three Del03 = new three(d3);
delegate void newD();
newD getdelegatesfromlist;
void Main(string[] args)
{
List<Delegate> mergedelegates = mergedels(Del01,Del02,Del03);
foreach(Delegate d in mergedelegates)
{
getdelegatesfromlist = new newD(????);
//then maybe invoke the delegate?
getdelegatesfromlist(); //??
}
}
List<Delegate> mergedels(params Delegate[] dels)
{
List<Delegate> dellist = new List<Delegate>();
foreach(Delegate d in Dels)
{
dellist.Add(d);
}
return dellist;
}
void d1(){...}
void d2(){...}
void d3(){...}
答案 0 :(得分:2)
而不是自己创建委托 您只需使用以下代码段
即可void Main(string[] args)
{
List<Action> mergedelegates = new List<Action> { d1, d2, d3 };
foreach (Action d in mergedelegates)
{
d.Invoke();
}
}
void d1() {...}
void d2() {...}
void d3() {...}
如果您想要一个带参数的函数,可以执行Action<TYPE1,TYPE2>
如果您想要函数返回值,可以使用Func<>
答案 1 :(得分:0)
如果您想使用方法列表,最好使用操作,但如果您想使用委托,可以这样做:
// creating the main delegates type
delegate void DelegateVoid ();
// declaring delegates
DelegateVoid Del01 = d1;
DelegateVoid Del02 = d2;
DelegateVoid Del03 = d3;
void Main(string[] args)
{
// looping and invoking delegates
foreach (DelegateVoid d in mergedels (Del01, Del02, Del03)) {
d.Invoke ();
}
}
List<DelegateVoid> mergedels (params DelegateVoid[] dels)
{
List<DelegateVoid> dellist = new List<DelegateVoid> ();
foreach (DelegateVoid d in dels) {
dellist.Add (d);
}
return dellist;
}
static void d1 ()
{
Debug.WriteLine ("Hello 1");
}
static void d2 ()
{
Debug.WriteLine ("Hello 2");
}
static void d3 ()
{
Debug.WriteLine ("Hello 3");
}