Один из моих фаворитов из коллекций apache commons - LazyMap, который использовал Transformer для создания значений "на лету" при выполнении map.get(newKey); // Will not return null!
.
Почему коллекции google не имеют одинакового значения?
Один из моих фаворитов из коллекций apache commons - LazyMap, который использовал Transformer для создания значений "на лету" при выполнении map.get(newKey); // Will not return null!
.
Почему коллекции google не имеют одинакового значения?
с 10.0, вместо этого guava имеет новый класс CacheBuilder, и он совместим с gwt.
Он называется new MapMaker().makeComputingMap(Function<? super K, ? extends V> computer)
Высокий.
Обратите внимание, что создателем карт является factory - вы можете создать его, установить все типы ссылочных объектов, свойства расширения (и даже время истечения срока действия!), а затем перейти к созданию множества вычислительных карт (или других типов) с одной строкой.
например. как и все остальное в библиотеке google-collection, это действительно хорошо - как только вы выяснили, где "это"
Я предлагаю написать собственный
public class LazyMap<K, V> extends ForwardingMap<K, V> {
final Function<? super K, ? extends V> factory;
final Map<K, V> delegate;
public static <K, V> LazyMap<K, V> lazyMap(final Map<K, V> map, final Supplier<? extends V> supplier) {
return new LazyMap<>(map, supplier);
}
public static <K, V> LazyMap<K, V> lazyMap(final Map<K, V> map, final Function<? super K, ? extends V> factory) {
return new LazyMap<>(map, factory);
}
private LazyMap(final Map<K, V> map, final Function<? super K, ? extends V> factory) {
this.factory = factory;
this.delegate = map;
}
private LazyMap(final Map<K, V> map, final Supplier<? extends V> supplier) {
this.factory = Functions.forSupplier(supplier);
this.delegate = map;
}
@Override
protected Map<K, V> delegate() {
return delegate;
}
@Override
public V get(final Object key) {
if (delegate().containsKey(key) == false) {
@SuppressWarnings("unchecked")
final K castKey = (K) key;
final V value = factory.apply(castKey);
delegate().put(castKey, value);
return value;
}
return delegate().get(key);
}
}