私の答えを始める前に、列挙型は列挙型であり、名前付きの有限コレクションであると言いたいです。
何かが静的な最終オブジェクトであること。そう
enum MyEnum {A,B,C;}
ボンネットの下には次のようなものがあります:
static final Object A = new MyEnum();
static final Object B = new MyEnum();
static final Object C = new MyEnum();
したがって、列挙型に可能なすべての型を使用することに関心があるとは思わないので (最終的には固定されたコンボがあります)、労力を最小限に抑え、選択したら実装が非常に簡単になるソリューションを提案します。サポートしたいタイプ。私のソリューションでは、Longs、Doubles、Points、および Strings を選択しました
このソリューションがニーズに合っていると思われる場合は、コードを直接提供します。コメントやリクエストに従って、喜んで改善します。
// MyType.java
package stackoverflow.answers;
import java.awt.Point;
public enum MyType {
LONG {
@Override
public Object validateValue(Object o) {
return (o instanceof Long) ? o : null;
}
@Override
public Object parse(String s) {
try {
return Long.valueOf(s);
} catch (Exception e) {
return null;
}
}
},
DOUBLE {
@Override
public Object validateValue(Object o) {
return (o instanceof Double) ? o : null;
}
@Override
public Object parse(String s) {
try {
return Double.valueOf(s);
} catch (Exception e) {
return null;
}
}
},
STRING {
@Override
public Object validateValue(Object o) {
return (o instanceof String) ? o : null;
}
@Override
public Object parse(String s) {
// stupid method, but needed.
return s;
}
},
AWTPOINT {
@Override
public Object validateValue(Object o) {
return (o instanceof Point) ? o : null;
}
@Override
public Object parse(String s) {
if (s == null)
return null;
String ss[] = s.split(",");
if (ss.length != 2)
return null;
try {
return new Point(Integer.valueOf(ss[0]), Integer.valueOf(ss[1]));
} catch (Exception e) {
return null;
}
}
};
public String toString(Object o) {
return o.toString();
}
public abstract Object validateValue(Object o);
public abstract Object parse(String s);
}
それから:
// GenericObject.java
package stackoverflow.answers;
public class GenericObject {
private MyType _type;
private Object _obj;
public GenericObject(MyType type) {
_type = type;
}
public void setValue(Object obj) {
_obj = _type.validateValue(obj);
}
public void valueOf(String s) {
_obj = _type.parse(s);
}
public String toString() {
return _type.toString(_obj);
}
}
そしてテストクラス:
package stackoverflow.answers;
public class EnumTest {
public static void main(String[] args) {
GenericObject o1 = new GenericObject(MyType.LONG);
o1.setValue(new Long(42));
GenericObject o2 = new GenericObject(MyType.DOUBLE);
o2.valueOf("3.14");
GenericObject o3 = new GenericObject(MyType.AWTPOINT);
o3.valueOf("4,-30");
System.out.println(o1);
System.out.println(o2);
System.out.println(o3);
}
}
アイデアは非常に単純です。新しい型をサポートする必要があるたびに、enum 要素を追加します。抽象メソッドを使用すると、値の保存、検証、および解析 (次はデータベースに保存しますか?) に必要なすべてを実装する必要があります。新しい関数が必要になるたびに (データベースへの保存など)、新しい抽象メソッドを追加すると、サポートすることを決定したすべての型に対してそれを実装する必要があります。
お役に立てれば。