[英]Java cast Long to Enum type issue
将Java long类型转换为Enum类型时出现了一些问题,无法找到解决方法。
这是我正在使用的:
public enum DataType {
IMAGES(1),
VIDEOS(2);
private int value;
private DataType(int i){
this.value = i;
}
}
我需要做这样的事情:
DataType dataType;
String thiz = "1";
long numb = Long.parseLong(thiz);
dataType = numb;
我得到的错误说:
将numb转换为DataType或将dataType转换为long。
第二种情景:
我有这个 :
static String[] packetType;
String tmp=incomingData.toString(); // where incomingData is byte[]
int lastLoc = 0;
int needsSize = packetFieldSizes[tmpCurrentField-1]; // where packetFieldSizes,tmpCurrentField are integers.
thiz=tmp.substring(lastLoc, needsSize);
packetType=thiz; // packetType = thiz copy; where thiz is the same as used above.
我试图将thiz转换为String []并使用valueOf,但是
有任何建议如何使思想工作?
提前致谢!
Enum
已经为每个实例提供了一个唯一的整数。 查看ordinal()
。 (请注意,它基于零。)
如果您需要从long
到DataType
您可以这样做
DataType dataType;
String thiz;
long numb = Long.parseLong(thiz);
dataType = DataType.values()[(int) numb];
在这个答案中可以找到枚举常量,字符串和整数的完整转换列表:
除了@ aioobe的答案 ,你可以推出自己的getInstance
方法。 这将提供更大的灵活性,因为您不会依赖序数。
public enum DataType {
.
.
public static final DataType getInstance(final int i){
for(DataType dt: DataType.values()){
if(dt.value == i){
return dt;
}
}
return null;
}
}
如果由于某种原因您需要自己分配数字,从而无法使用aioobe的良好解决方案,您可以执行以下操作:
public enum DataType {
IMAGES(1),
VIDEOS(2);
private final int value;
private DataType(int i){
this.value=i;
}
public static DataType getByValue(int i) {
for(DataType dt : DataType.values()) {
if(dt.value == i) {
return dt;
}
}
throw new IllegalArgumentException("no datatype with " + i + " exists");
}
静态方法getByValue()
使用提供的数字搜索DataType
。
来自aioobe的正确答案。 也许其他一些问题?
对于枚举索引,你最好使用int而不是long。 它可能像:
String indexAsString;
int index = Integer.parseInt(indexAsString)-1;
DataType dataType = DataType.values()[index];
请注意“-1”,因为数组是从零开始的,而您的索引是从1开始的。
如果传递给枚举的数字是索引而不是某些任意代码,如行中的分辨率或字符数,则ordinal()将起作用。
我使用值的访问方法,分辨率索引和将数字解析为枚举值的静态方法扩展了枚举。 干得好...
public enum DataType {
IMAGES(1),
VIDEOS(2);
private int value;
DataType(int i){
this.value=i;
}
static final Map<Integer,DataType> inverseIndex;
static {
inverseIndex = new HashMap<Integer,DataType> ();
for (DataType dt:DataType.values()) {
inverseIndex.put(dt.getValue(), dt);
}
}
public int getValue() {
return value;
}
public static DataType resolve(int number) {
return inverseIndex.get(number);
}
}
请注意,此解决方案不起作用是您的地图枚举值不是双射的,因此您的enumType中的枚举可能只有不同的值。
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.