apache commons-collectionsからの私のお気に入りの1つは、トランスフォーマーを使用して実行時にその場で値をインスタンス化するLazyMapでしたmap.get(newKey); // Will not return null!
。
なぜグーグルコレクションは同じではないのですか?
apache commons-collectionsからの私のお気に入りの1つは、トランスフォーマーを使用して実行時にその場で値をインスタンス化するLazyMapでしたmap.get(newKey); // Will not return null!
。
なぜグーグルコレクションは同じではないのですか?
それは呼ばれていますnew MapMaker().makeComputingMap(Function<? super K, ? extends V> computer)
素晴らしい。
マップメーカーはファクトリであることに注意してください。1つ作成し、すべてのオブジェクト参照タイプ、拡張プロパティ(さらにはオブジェクトの有効期限も!)を設定してから、1回の呼び出しで多くのコンピューティングマップ(または他のタイプ)を作成できます。
たとえば、google-collectionsライブラリに関する他のほとんどすべてのように、それは本当に良いです-「それ」がどこにあるかを理解したら
10.0以降、guavaには代わりに新しいクラスCacheBuilderがあり、gwt互換です。
これらは違いです。
私はあなた自身を書くことを提案します
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);
}
}