如果你知道的话,我有一个用于ProjectEuler的C#项目。
为此,我使用一个抽象类,我们称之为"X">
public abstract class X {
protected abstract void SomeFunction()
}
这个项目有600多个问题需要解决。对于每个问题,我创建一个继承自 X 的类。类的名称始终是"Baseclassname",后跟一个数字
考核:
public class X2 : X {
public override void SomeFunction()
}
在运行时,我通过控制台输入一个有效的整数来选择问题。这个整数进入开关并产生相应的问题,如果 '_problem' 不等于 null,则执行 someFunction。
X _problem = null;
int someInput; //any valid input readin via Console
switch(someInput)
{
case 1:
_problem = new X1();
break;
case 2:
_problem = new X2();
break;
.
.
.
case 610:
_problem = new X610();
break;
}
_promblem?.someFunction();
所以我对社区的问题是,如何避免超过600个案例的转换案例。有没有更好的解决方案来做到这一点?
我希望这个问题写得很好,因为这是我的第一个。 :)
编辑:一些"键,值"对数组只有在编译期间自动添加所有现有对时才是理想的。
尝试按如下方式进行反射;
X _problem = null;
int someInput; //any valid input readin via Console
try
{
_problem = Assembly.GetExecutingAssembly().CreateInstance($«X{someInput}») as X
}
catch{}
_promblem?.someFunction();
以下是您可以使用用户选项菜单执行的操作的框架:
//Get all the types that inherit from 'X'
var types = Assembly.GetExecutingAssembly().GetTypes()
.Where(t => t.IsClass && !t.IsAbstract && t.IsSubclassOf(typeof(X)))
.ToList();
Console.WriteLine("Choose a class to run");
var index = 0;
foreach (var type in types)
{
Console.WriteLine($"{index++}: {type.Name}");
}
Console.Write("Enter number: ");
//Much better to use "TryParse" here and validate the input
index = int.Parse(Console.ReadLine());
var instance = (X)Activator.CreateInstance(types[index]);
instance.SomeFunction();
请注意,您必须将保护级别更改为public
才能使其正常工作。
如果名称格式正确(也就是说,您可以从输入中生成类名(,则很容易使用System.Reflection.Assembly的CreateInstance方法,然后强制转换为抽象类型和acall基成员。