我必须在不同的功能中重复使用相同的开关盒。在不同的功能中,开关盒的定义会有所不同。例如:
int groupID = somenumber;
private void FunctionA()
{
switch (groupID)
{
case 0:
// Do Action A
break;
case 1:
// Do Action B
break;
case 2:
// Do Action C
break;
}
}
private void FunctionB()
{
switch (groupID)
{
case 0:
// Do Action Z
break;
case 1:
// Do Action X
break;
case 2:
// Do Action Y
break;
}
}
这是一次使用相同开关盒的任何方法,但定义可能不同吗?
答案 0 :(得分:6)
我真诚地相信有更好的方式来做你想要完成的事情,但你需要给我们更多细节。
在目前的情况下,一个可能的解决方案是:
private void SwitchStuff(Action action0, Action action1, Action action2)
{
switch (groupID)
{
case 0:
action0();
break;
case 1:
action1();
break;
case 2:
action2();
break;
}
}
并使用它:
SwitchStuff(DoActionA, DoActionB, DoActionC);
SwitchStuff(DoActionX, DoActionY, DoActionZ);
这些行为是lambda / normal方法。
答案 1 :(得分:5)
一种可能性是使用一个使用Action委托的方法,如下所示:
private void MyFunction(int groupID, Action a, Action b, Action c)
{
switch (groupID)
{
case 0:
a();
break;
case 1:
b();
break;
case 2:
c();
break;
}
}
然后你可以这样称呼它:
MyFunction( groupId, A, B, C );
或
MyFunction( groupId, Z, X, Y );
修改强>
或者更好的方法是Matthew Watson建议的变体:
将方法更改为
private void MyFunction(int groupID, params Action[] actions)
{
actions[groupId]();
}
并摆脱整个开关案例。你可以用与上面完全相同的方式调用它。
答案 2 :(得分:4)
您可以使用多态替换switch语句。创建代表您的组的接口或基类:
public interface Group
{
void FunctionA(); // if Group is a class, then make these methods
void FunctionB(); // virtual or abstract
}
然后为每个组创建类(抱歉,我不知道0,1,2在这里意味着什么,所以考虑更好的描述性名称):
public class Group0 : Group
{
public void FunctionA()
{
// Do Action A
}
public void FunctionB()
{
// Do Action Z
}
}
然后您创建适当的组实例:
private IGroup CreateGroup(int groupID)
{
switch (groupID)
{
case 0: return new Group0();
case 1: return new Group1();
case 2: return new Group2();
default:
throw new ArgumentException();
}
}
在你的应用程序中使用这个group实例(应用程序不知道它正在使用哪个组实现):
IGroup group = CreateGroup(somenumber);
group.FunctionA(); // if group is Group1 then do action B
group.FunctionB(); // if group is Group1 then do action X