为了与某些硬件同步,我创建了一个包含通用类的Datamodel
用于在HashMap中存储不同类型的对象的DataField。
HashMap myDictionary。
现在发现,如果我将DataField存储到DataField中,则可以在DataField中保存一个字符串。
有什么办法可以防止这种情况的发生。
这是我的代码:
public class DataField<T> implements IDataField<T> {
//region Fields
private T _value;
private boolean _hasChanged;
private ChildObserable<T> _hasChangedObserverable;
//endregion
//region Methodes
public DataField(T val) throws IllegalValueException {
if(val.getClass() != _value.getClass()) throw new IllegalValueException();
_value =val;
_hasChanged=false;
_hasChangedObserverable=new ChildObserable<>();
}
public DataField(T val,Observer observer){
_value =val;
_hasChanged=false;
_hasChangedObserverable=new ChildObserable<>();
addChangeObserver(observer);
}
//region getters
@Override
public T getValue() {
return _value;
}
@Override
public boolean hasBeChanged() {
return _hasChanged;
}
//endregion
//region setters
@Override
public void setValue(T value) throws IllegalValueException {
if(value.getClass()!= _value.getClass()) throw new IllegalValueException();
if(value!=_value) {
_value = value;
_hasChanged=true;
_hasChangedObserverable.sendValue(_value);
}
}
@Override
public void clearChangedState() {
_hasChanged=false;
}
//endregion
//region observers
@Override
public void addChangeObserver(Observer observer) {
_hasChangedObserverable.addObserver(observer);
}
@Override
public void removeChangeObserver(Observer observer) {
_hasChangedObserverable.deleteObserver(observer);
}
//endregion
//endregion
}
这是我的意思的代码示例:
DataField dataField = new DataField<Integer>(5);
dataField.setValue(true); // This can be prevented because of checking Class
DataField dataField = new DataField<String>(null);
dataField.setValue(5); // This can not be prevented because of NullPointer Exception
我找到了一些这样的解决方案How to keep generic type of nested generics with class tokens
但我不想两次宽恕班级
我的另一个想法是使用像C#这样的default(T)函数将My Value预设为特定的Type。
感谢帮助
最佳答案
我使用第二个构造函数和一个类字段解决了它。
public DataField(T val) throws IllegalValueException {
if(val==null) throw new IllegalArgumentException("Class type couldn't be resolved from null");
_value =val;
_class=val.getClass();
_hasChanged=false;
_hasChangedObserverable=new ChildObserable<>();
}
public DataField(T val,Class<T> classType) throws IllegalValueException {
if(val!=null && val.getClass()!=classType) throw new IllegalArgumentException("Type of val and classType are Different");
_class=classType;
_value=val;
_hasChanged=false;
_hasChangedObserverable=new ChildObserable<>();
}
@Override
public void setValue(T value) throws IllegalValueException {
if(_class!= value.getClass()) throw new IllegalValueException();
if(value!=_value) {
_value = value;
_hasChanged=true;
_hasChangedObserverable.sendValue(_value);
}
}
感谢帮助