@Override @Nonnull public <K2 extends K> UpdatableLHashSeparateKVObjDoubleMapGO<K2> newUpdatableMapOf( K2 k1, double v1, K2 k2, double v2, K2 k3, double v3, K2 k4, double v4) { UpdatableLHashSeparateKVObjDoubleMapGO<K2> map = newUpdatableMap(4); map.put(k1, v1); map.put(k2, v2); map.put(k3, v3); map.put(k4, v4); return map; }
@Override @Nonnull public <K2 extends K> UpdatableLHashSeparateKVObjDoubleMapGO<K2> newUpdatableMap( Map<? extends K2, Double> map, int expectedSize) { if (map instanceof ObjDoubleMap) { // noinspection unchecked ObjDoubleMap<K2> objDoubleMap = (ObjDoubleMap<K2>) map; if (map instanceof SeparateKVObjDoubleLHash) { SeparateKVObjDoubleLHash hash = (SeparateKVObjDoubleLHash) map; if (hash.hashConfig().equals(hashConf) && objDoubleMap.keyEquivalence().equals(getKeyEquivalence())) { UpdatableLHashSeparateKVObjDoubleMapGO<K2> res = uninitializedUpdatableMap(); res.copy(hash); return res; } } UpdatableLHashSeparateKVObjDoubleMapGO<K2> res = newUpdatableMap(expectedSize); res.putAll(map); return res; } else { UpdatableLHashSeparateKVObjDoubleMapGO<K2> res = newUpdatableMap(expectedSize); for (Map.Entry<? extends K2, Double> entry : map.entrySet()) { res.put(entry.getKey(), entry.getValue()); } return res; } } }
@Override @Nonnull public <K2 extends K> UpdatableLHashSeparateKVObjDoubleMapGO<K2> newUpdatableMapOf( K2 k1, double v1, K2 k2, double v2, K2 k3, double v3, K2 k4, double v4) { UpdatableLHashSeparateKVObjDoubleMapGO<K2> map = newUpdatableMap(4); map.put(k1, v1); map.put(k2, v2); map.put(k3, v3); map.put(k4, v4); return map; }
@Override @Nonnull public <K2 extends K> UpdatableLHashSeparateKVObjDoubleMapGO<K2> newUpdatableMap( Map<? extends K2, Double> map, int expectedSize) { if (map instanceof ObjDoubleMap) { // noinspection unchecked ObjDoubleMap<K2> objDoubleMap = (ObjDoubleMap<K2>) map; if (map instanceof SeparateKVObjDoubleLHash) { SeparateKVObjDoubleLHash hash = (SeparateKVObjDoubleLHash) map; if (hash.hashConfig().equals(hashConf) && objDoubleMap.keyEquivalence().equals(getKeyEquivalence())) { UpdatableLHashSeparateKVObjDoubleMapGO<K2> res = uninitializedUpdatableMap(); res.copy(hash); return res; } } UpdatableLHashSeparateKVObjDoubleMapGO<K2> res = newUpdatableMap(expectedSize); res.putAll(map); return res; } else { UpdatableLHashSeparateKVObjDoubleMapGO<K2> res = newUpdatableMap(expectedSize); for (Map.Entry<? extends K2, Double> entry : map.entrySet()) { res.put(entry.getKey(), entry.getValue()); } return res; } } }
@Override @Nonnull public <K2 extends K> UpdatableLHashSeparateKVObjDoubleMapGO<K2> newUpdatableMapOf( K2 k1, double v1, K2 k2, double v2, K2 k3, double v3, K2 k4, double v4, K2 k5, double v5) { UpdatableLHashSeparateKVObjDoubleMapGO<K2> map = newUpdatableMap(5); map.put(k1, v1); map.put(k2, v2); map.put(k3, v3); map.put(k4, v4); map.put(k5, v5); return map; }
@Override @Nonnull public <K2 extends K> UpdatableLHashSeparateKVObjDoubleMapGO<K2> newUpdatableMapOf( K2 k1, double v1, K2 k2, double v2, K2 k3, double v3, K2 k4, double v4, K2 k5, double v5) { UpdatableLHashSeparateKVObjDoubleMapGO<K2> map = newUpdatableMap(5); map.put(k1, v1); map.put(k2, v2); map.put(k3, v3); map.put(k4, v4); map.put(k5, v5); return map; }
@Override @Nonnull public <K2 extends K> UpdatableLHashSeparateKVObjDoubleMapGO<K2> newUpdatableMapOf( K2 k1, double v1) { UpdatableLHashSeparateKVObjDoubleMapGO<K2> map = newUpdatableMap(1); map.put(k1, v1); return map; }
@Override @Nonnull public <K2 extends K> UpdatableLHashSeparateKVObjDoubleMapGO<K2> newUpdatableMapOf( K2 k1, double v1) { UpdatableLHashSeparateKVObjDoubleMapGO<K2> map = newUpdatableMap(1); map.put(k1, v1); return map; }
@Override @Nonnull public <K2 extends K> UpdatableLHashSeparateKVObjDoubleMapGO<K2> newUpdatableMap( K2[] keys, Double[] values, int expectedSize) { UpdatableLHashSeparateKVObjDoubleMapGO<K2> map = newUpdatableMap(expectedSize); int keysLen = keys.length; if (keysLen != values.length) throw new IllegalArgumentException("keys and values arrays must have the same size"); for (int i = 0; i < keys.length; i++) { map.put(keys[i], values[i]); } return shrunk(map); }
@Override @Nonnull public <K2 extends K> UpdatableLHashSeparateKVObjDoubleMapGO<K2> newUpdatableMap( Iterable<? extends K2> keys, Iterable<Double> values, int expectedSize) { UpdatableLHashSeparateKVObjDoubleMapGO<K2> map = newUpdatableMap(expectedSize); Iterator<? extends K2> keysIt = keys.iterator(); Iterator<Double> valuesIt = values.iterator(); try { while (keysIt.hasNext()) { map.put(keysIt.next(), valuesIt.next()); } return shrunk(map); } catch (NoSuchElementException e) { throw new IllegalArgumentException( "keys and values iterables must have the same size", e); } }
@Override @Nonnull public <K2 extends K> UpdatableLHashSeparateKVObjDoubleMapGO<K2> newUpdatableMap( Iterable<? extends K2> keys, Iterable<Double> values, int expectedSize) { UpdatableLHashSeparateKVObjDoubleMapGO<K2> map = newUpdatableMap(expectedSize); Iterator<? extends K2> keysIt = keys.iterator(); Iterator<Double> valuesIt = values.iterator(); try { while (keysIt.hasNext()) { map.put(keysIt.next(), valuesIt.next()); } return shrunk(map); } catch (NoSuchElementException e) { throw new IllegalArgumentException( "keys and values iterables must have the same size", e); } }
@Override @Nonnull public <K2 extends K> UpdatableLHashSeparateKVObjDoubleMapGO<K2> newUpdatableMap( K2[] keys, double[] values, int expectedSize) { UpdatableLHashSeparateKVObjDoubleMapGO<K2> map = newUpdatableMap(expectedSize); int keysLen = keys.length; if (keysLen != values.length) throw new IllegalArgumentException("keys and values arrays must have the same size"); for (int i = 0; i < keys.length; i++) { map.put(keys[i], values[i]); } return shrunk(map); }
@Override @Nonnull public <K2 extends K> UpdatableLHashSeparateKVObjDoubleMapGO<K2> newUpdatableMap( K2[] keys, double[] values, int expectedSize) { UpdatableLHashSeparateKVObjDoubleMapGO<K2> map = newUpdatableMap(expectedSize); int keysLen = keys.length; if (keysLen != values.length) throw new IllegalArgumentException("keys and values arrays must have the same size"); for (int i = 0; i < keys.length; i++) { map.put(keys[i], values[i]); } return shrunk(map); }
@Override @Nonnull public <K2 extends K> UpdatableLHashSeparateKVObjDoubleMapGO<K2> newUpdatableMap( K2[] keys, Double[] values, int expectedSize) { UpdatableLHashSeparateKVObjDoubleMapGO<K2> map = newUpdatableMap(expectedSize); int keysLen = keys.length; if (keysLen != values.length) throw new IllegalArgumentException("keys and values arrays must have the same size"); for (int i = 0; i < keys.length; i++) { map.put(keys[i], values[i]); } return shrunk(map); }