我有FaultType enum超过100名成员.
public enum FaultType
{
FaultType1,
FaultType2,
FaultType3,
FaultType4,
FaultType5,
}
Run Code Online (Sandbox Code Playgroud)
我有一个FaultTypeConstants class对应的FaultType.
public class FaultTypeConstants
{
public const int FaultType1 = 600;
public const int FaultType2 = 100;
public const int FaultType3 = 453;
public const int FaultType4 = 200;
public const int FaultType5 = 300;
}
Run Code Online (Sandbox Code Playgroud)
我试过了..
public static List<FaultType> GetFaults(List<int> FaultConstants)
{
var faults = new List<FaultType>();
FaultConstants.ForEach(fc => {
switch (fc)
{
case FaultTypeConstants.FaultType1:
faults.Add(FaultType.FaultType1);
break;
case FaultTypeConstants.FaultType2:
faults.Add(FaultType.FaultType2);
break;
case FaultTypeConstants.FaultType3:
faults.Add(FaultType.FaultType3);
break;
case FaultTypeConstants.FaultType4:
faults.Add(FaultType.FaultType4);
break;
case FaultTypeConstants.FaultType5:
faults.Add(FaultType.FaultType5);
break;
default:
break;
}
});
return faults;
}
Run Code Online (Sandbox Code Playgroud)
现在,我如何填充List<FaultType>基于FaultTypeConstants价值观?
只需提供常量作为枚举本身的一部分:
public enum FaultType
{
FaultType1 = 600,
FaultType2 = 100,
FaultType3 = 453,
FaultType4 = 200,
FaultType5 = 300,
}
Run Code Online (Sandbox Code Playgroud)
然后你可以投下:
FaultType ft = (FaultType) 600;
Run Code Online (Sandbox Code Playgroud)
对于列表,您可以循环迭代foreach,或者如果您喜欢LINQ,您可以使用:
List<FaultType> listOfFaultTypes = listOfInts.Cast<FaultType>().ToList();
Run Code Online (Sandbox Code Playgroud)
UPDATE
根据您的评论,您根本无法更改枚举,我建议您构建一个可用于查找的字典.
private static readonly Dictionary<int, FaultType> FaultTypeDictionary =
Enum.GetValues(typeof(FaultType))
.Cast<FaultType>()
.ToDictionary(
x => (int)typeof(FaultTypeConstants).GetField(x.ToString()).GetValue(null),
x => x);
public static List<FaultType> GetFaults(List<int> faults)
{
return faults.Select(x => FaultTypeDictionary[x]).ToList();
}
Run Code Online (Sandbox Code Playgroud)
它使用反射,但只对枚举进行一次传递.由于它是静态的,因此您无需为每次查找执行此操作.