是否有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>
。有什么方便的方法吗?我的头转了一圈,正在浪费我的精力,试图重新发明这种东西。
最佳答案
除非有迫切的原因,否则我将扩展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
。