是否有java.beans.PropertyChangeSupport
或com.jgoodies.binding.beans.ExtendedPropertyChangeSupport
的版本有助于沿着Map或EnumMap的行支持更改侦听器? (具有已知有限键的键值存储,并为地图中的所有值更改侦听器)
我真的不需要bean类型访问,我有许多不同的统计信息,如:
interface hasName() {
public String getName();
}
enum StatisticType implements hasName {
MILES_DRIVEN, BURGERS_SERVED, CUSTOMERS_HELPED, BIRDS_WATCHED;
@Override public String getName() { return name(); }
}
我希望发布如下界面:
interface KeyValueStore<K extends hasName,V>
{
void setValue(K key, V value);
V getValue(K key);
void addPropertyChangeListener(PropertyChangeListener listener);
void removePropertyChangeListener(PropertyChangeListener listener);
/*
* when setValue() is called, this should send PropertyChangeEvents
* to all listeners, with the property name of K.getName()
*/
}
所以我可以在我的应用程序中使用KeyValueStore<StatisticType, Integer>
。
有没有方便的方法呢?我的脑袋旋转着,它正在削弱我的能量,试图重新发明轮子。
答案 0 :(得分:1)
除非有迫切的理由,否则我会延长Map
并使用put
和get
代替setValue
和getValue
。
我有一个经常使用的界面:
public interface PropertyChangeNotification {
void addPropertyChangeListener(String property, PropertyChangeListener listener);
void removePropertyChangeListener(String property, PropertyChangeListener listener);
void addPropertyChangeListener(PropertyChangeListener listener);
void removePropertyChangeListener(PropertyChangeListener listener);
}
通过它,您的界面变为:
interface KeyValueStore<K extends hasName,V>
extends Map<K,V>, PropertyChangeNotification
{
}
然后你的实现结束了这样的事情:
public class MyKeyStore<K extends hasName, V>
extends HashMap<K,V>
implements KeyValueStore<K,V>
{
private PropertyChangeSupport changer = new PropertyChangeSupport(this);
public void put(K key, V value)
{
V old = get(K);
super.put(key,value);
changer.firePropertyChange(key.getName(), value, old);
}
}
未显示PropertyChangeNotification功能的4种方法,只需委托给changer
。