com.koloboke.collect.impl.hash.QHashSeparateKVShortObjMapFactoryGO Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of koloboke-impl-jdk8 Show documentation
Show all versions of koloboke-impl-jdk8 Show documentation
Carefully designed and efficient extension of the Java Collections Framework with primitive specializations and more, built for Java 8 (Implementation)
The newest version!
/*
* Copyright 2014 the original author or authors.
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
package com.koloboke.collect.impl.hash;
import com.koloboke.collect.*;
import com.koloboke.collect.hash.*;
import com.koloboke.collect.impl.*;
import com.koloboke.collect.map.hash.HashShortObjMapFactory;
import java.util.function.Consumer;
import java.util.function.Predicate;
import com.koloboke.collect.map.hash.HashShortObjMap;
import javax.annotation.Nonnull;
import java.util.*;
import static com.koloboke.collect.impl.Containers.sizeAsInt;
import static com.koloboke.collect.impl.hash.LHashCapacities.configIsSuitableForMutableLHash;
public abstract class QHashSeparateKVShortObjMapFactoryGO
extends QHashSeparateKVShortObjMapFactorySO {
QHashSeparateKVShortObjMapFactoryGO(HashConfig hashConf, int defaultExpectedSize
, short lower, short upper) {
super(hashConf, defaultExpectedSize, lower, upper);
}
abstract HashShortObjMapFactory thisWith(HashConfig hashConf, int defaultExpectedSize, short lower, short upper);
abstract HashShortObjMapFactory lHashLikeThisWith(HashConfig hashConf, int defaultExpectedSize, short lower, short upper);
abstract HashShortObjMapFactory qHashLikeThisWith(HashConfig hashConf, int defaultExpectedSize, short lower, short upper);
@Override
public final HashShortObjMapFactory withHashConfig(@Nonnull HashConfig hashConf) {
if (configIsSuitableForMutableLHash(hashConf))
return lHashLikeThisWith(hashConf, getDefaultExpectedSize()
, getLowerKeyDomainBound(), getUpperKeyDomainBound());
return qHashLikeThisWith(hashConf, getDefaultExpectedSize()
, getLowerKeyDomainBound(), getUpperKeyDomainBound());
}
@Override
public final HashShortObjMapFactory withDefaultExpectedSize(int defaultExpectedSize) {
if (defaultExpectedSize == getDefaultExpectedSize())
return this;
return thisWith(getHashConfig(), defaultExpectedSize
, getLowerKeyDomainBound(), getUpperKeyDomainBound());
}
final HashShortObjMapFactory withDomain(short lower, short upper) {
if (lower == getLowerKeyDomainBound() && upper == getUpperKeyDomainBound())
return this;
return thisWith(getHashConfig(), getDefaultExpectedSize(), lower, upper);
}
@Override
public final HashShortObjMapFactory withKeysDomain(short lower, short upper) {
if (lower > upper)
throw new IllegalArgumentException("minPossibleKey shouldn't be greater " +
"than maxPossibleKey");
return withDomain(lower, upper);
}
@Override
public final HashShortObjMapFactory withKeysDomainComplement(short lower, short upper) {
if (lower > upper)
throw new IllegalArgumentException("minImpossibleKey shouldn't be greater " +
"than maxImpossibleKey");
return withDomain((short) (upper + 1), (short) (lower - 1));
}
@Override
public String toString() {
return "HashShortObjMapFactory[" + commonString() + keySpecialString() +
",valueEquivalence=" + getValueEquivalence() +
"]";
}
@Override
public int hashCode() {
int hashCode = keySpecialHashCode(commonHashCode());
hashCode = hashCode * 31 + getValueEquivalence().hashCode();
return hashCode;
}
@Override
public boolean equals(Object obj) {
if (this == obj)
return true;
if (obj instanceof HashShortObjMapFactory) {
HashShortObjMapFactory factory = (HashShortObjMapFactory) obj;
return commonEquals(factory) && keySpecialEquals(factory) &&
getValueEquivalence().equals(factory.getValueEquivalence())
;
} else {
return false;
}
}
@Override
@Nonnull
public Equivalence getValueEquivalence() {
return Equivalence.defaultEquality();
}
private UpdatableQHashSeparateKVShortObjMapGO shrunk(
UpdatableQHashSeparateKVShortObjMapGO map) {
Predicate shrinkCondition;
if ((shrinkCondition = hashConf.getShrinkCondition()) != null) {
if (shrinkCondition.test(map))
map.shrink();
}
return map;
}
@Override
@Nonnull
public UpdatableQHashSeparateKVShortObjMapGO newUpdatableMap() {
return this.newUpdatableMap(getDefaultExpectedSize());
}
@Override
@Nonnull
public MutableQHashSeparateKVShortObjMapGO newMutableMap() {
return this.newMutableMap(getDefaultExpectedSize());
}
@Override
@Nonnull
public UpdatableQHashSeparateKVShortObjMapGO newUpdatableMap(
Map map) {
return shrunk(super.newUpdatableMap(map));
}
@Override
@Nonnull
public UpdatableQHashSeparateKVShortObjMapGO newUpdatableMap(
Map map1, Map map2) {
long expectedSize = (long) map1.size();
expectedSize += (long) map2.size();
return this.newUpdatableMap(map1, map2, sizeAsInt(expectedSize));
}
@Override
@Nonnull
public UpdatableQHashSeparateKVShortObjMapGO newUpdatableMap(
Map map1, Map map2,
Map map3) {
long expectedSize = (long) map1.size();
expectedSize += (long) map2.size();
expectedSize += (long) map3.size();
return this.newUpdatableMap(map1, map2, map3, sizeAsInt(expectedSize));
}
@Override
@Nonnull
public UpdatableQHashSeparateKVShortObjMapGO newUpdatableMap(
Map map1, Map map2,
Map map3, Map map4) {
long expectedSize = (long) map1.size();
expectedSize += (long) map2.size();
expectedSize += (long) map3.size();
expectedSize += (long) map4.size();
return this.newUpdatableMap(map1, map2, map3, map4, sizeAsInt(expectedSize));
}
@Override
@Nonnull
public UpdatableQHashSeparateKVShortObjMapGO newUpdatableMap(
Map map1, Map map2,
Map map3, Map map4,
Map map5) {
long expectedSize = (long) map1.size();
expectedSize += (long) map2.size();
expectedSize += (long) map3.size();
expectedSize += (long) map4.size();
expectedSize += (long) map5.size();
return this.newUpdatableMap(map1, map2, map3, map4, map5, sizeAsInt(expectedSize));
}
@Override
@Nonnull
public UpdatableQHashSeparateKVShortObjMapGO newUpdatableMap(
Map map1, Map map2,
int expectedSize) {
UpdatableQHashSeparateKVShortObjMapGO map = newUpdatableMap(expectedSize);
map.putAll(map1);
map.putAll(map2);
return shrunk(map);
}
@Override
@Nonnull
public UpdatableQHashSeparateKVShortObjMapGO newUpdatableMap(
Map map1, Map map2,
Map map3, int expectedSize) {
UpdatableQHashSeparateKVShortObjMapGO map = newUpdatableMap(expectedSize);
map.putAll(map1);
map.putAll(map2);
map.putAll(map3);
return shrunk(map);
}
@Override
@Nonnull
public UpdatableQHashSeparateKVShortObjMapGO newUpdatableMap(
Map map1, Map map2,
Map map3, Map map4,
int expectedSize) {
UpdatableQHashSeparateKVShortObjMapGO map = newUpdatableMap(expectedSize);
map.putAll(map1);
map.putAll(map2);
map.putAll(map3);
map.putAll(map4);
return shrunk(map);
}
@Override
@Nonnull
public UpdatableQHashSeparateKVShortObjMapGO newUpdatableMap(
Map map1, Map map2,
Map map3, Map map4,
Map map5, int expectedSize) {
UpdatableQHashSeparateKVShortObjMapGO map = newUpdatableMap(expectedSize);
map.putAll(map1);
map.putAll(map2);
map.putAll(map3);
map.putAll(map4);
map.putAll(map5);
return shrunk(map);
}
@Override
@Nonnull
public UpdatableQHashSeparateKVShortObjMapGO newUpdatableMap(
Consumer> entriesSupplier) {
return this.newUpdatableMap(entriesSupplier, getDefaultExpectedSize());
}
@Override
@Nonnull
public UpdatableQHashSeparateKVShortObjMapGO newUpdatableMap(
Consumer> entriesSupplier,
int expectedSize) {
final UpdatableQHashSeparateKVShortObjMapGO map = newUpdatableMap(expectedSize);
entriesSupplier.accept(new com.koloboke.function.ShortObjConsumer() {
@Override
public void accept(short k, V2 v) {
map.put(k, v);
}
});
return shrunk(map);
}
@Override
@Nonnull
public UpdatableQHashSeparateKVShortObjMapGO newUpdatableMap(
short[] keys, V2[] values) {
return this.newUpdatableMap(keys, values, keys.length);
}
@Override
@Nonnull
public UpdatableQHashSeparateKVShortObjMapGO newUpdatableMap(
short[] keys, V2[] values, int expectedSize) {
UpdatableQHashSeparateKVShortObjMapGO 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 UpdatableQHashSeparateKVShortObjMapGO newUpdatableMap(
Short[] keys, V2[] values) {
return this.newUpdatableMap(keys, values, keys.length);
}
@Override
@Nonnull
public UpdatableQHashSeparateKVShortObjMapGO newUpdatableMap(
Short[] keys, V2[] values, int expectedSize) {
UpdatableQHashSeparateKVShortObjMapGO 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 UpdatableQHashSeparateKVShortObjMapGO newUpdatableMap(
Iterable keys, Iterable extends V2> values) {
int expectedSize = keys instanceof Collection ? ((Collection) keys).size() :
getDefaultExpectedSize();
return this.newUpdatableMap(keys, values, expectedSize);
}
@Override
@Nonnull
public UpdatableQHashSeparateKVShortObjMapGO newUpdatableMap(
Iterable keys, Iterable extends V2> values, int expectedSize) {
UpdatableQHashSeparateKVShortObjMapGO map = newUpdatableMap(expectedSize);
Iterator keysIt = keys.iterator();
Iterator extends V2> 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 UpdatableQHashSeparateKVShortObjMapGO newUpdatableMapOf(
short k1, V2 v1) {
UpdatableQHashSeparateKVShortObjMapGO map = newUpdatableMap(1);
map.put(k1, v1);
return map;
}
@Override
public UpdatableQHashSeparateKVShortObjMapGO newUpdatableMapOf(
short k1, V2 v1, short k2, V2 v2) {
UpdatableQHashSeparateKVShortObjMapGO map = newUpdatableMap(2);
map.put(k1, v1);
map.put(k2, v2);
return map;
}
@Override
@Nonnull
public UpdatableQHashSeparateKVShortObjMapGO newUpdatableMapOf(
short k1, V2 v1, short k2, V2 v2,
short k3, V2 v3) {
UpdatableQHashSeparateKVShortObjMapGO map = newUpdatableMap(3);
map.put(k1, v1);
map.put(k2, v2);
map.put(k3, v3);
return map;
}
@Override
@Nonnull
public UpdatableQHashSeparateKVShortObjMapGO newUpdatableMapOf(
short k1, V2 v1, short k2, V2 v2,
short k3, V2 v3, short k4, V2 v4) {
UpdatableQHashSeparateKVShortObjMapGO map = newUpdatableMap(4);
map.put(k1, v1);
map.put(k2, v2);
map.put(k3, v3);
map.put(k4, v4);
return map;
}
@Override
@Nonnull
public UpdatableQHashSeparateKVShortObjMapGO newUpdatableMapOf(
short k1, V2 v1, short k2, V2 v2,
short k3, V2 v3, short k4, V2 v4,
short k5, V2 v5) {
UpdatableQHashSeparateKVShortObjMapGO 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 HashShortObjMap newMutableMap(Map map1,
Map map2, int expectedSize) {
MutableQHashSeparateKVShortObjMapGO res = uninitializedMutableMap();
res.move(this.newUpdatableMap(map1, map2, expectedSize));
return res;
}
@Override
@Nonnull
public HashShortObjMap newMutableMap(Map map1,
Map map2, Map map3, int expectedSize) {
MutableQHashSeparateKVShortObjMapGO res = uninitializedMutableMap();
res.move(this.newUpdatableMap(map1, map2, map3, expectedSize));
return res;
}
@Override
@Nonnull
public HashShortObjMap newMutableMap(Map map1,
Map map2, Map map3,
Map map4, int expectedSize) {
MutableQHashSeparateKVShortObjMapGO res = uninitializedMutableMap();
res.move(this.newUpdatableMap(map1, map2, map3, map4, expectedSize));
return res;
}
@Override
@Nonnull
public HashShortObjMap newMutableMap(Map map1,
Map map2, Map map3,
Map map4, Map map5, int expectedSize) {
MutableQHashSeparateKVShortObjMapGO res = uninitializedMutableMap();
res.move(this.newUpdatableMap(map1, map2, map3, map4, map5, expectedSize));
return res;
}
@Override
@Nonnull
public HashShortObjMap newMutableMap(
Consumer> entriesSupplier
, int expectedSize) {
MutableQHashSeparateKVShortObjMapGO map = uninitializedMutableMap();
map.move(this.newUpdatableMap(entriesSupplier, expectedSize));
return map;
}
@Override
@Nonnull
public HashShortObjMap newMutableMap(short[] keys,
V2[] values, int expectedSize) {
MutableQHashSeparateKVShortObjMapGO map = uninitializedMutableMap();
map.move(this.newUpdatableMap(keys, values, expectedSize));
return map;
}
@Override
@Nonnull
public HashShortObjMap newMutableMap(
Short[] keys, V2[] values, int expectedSize) {
MutableQHashSeparateKVShortObjMapGO map = uninitializedMutableMap();
map.move(this.newUpdatableMap(keys, values, expectedSize));
return map;
}
@Override
@Nonnull
public HashShortObjMap newMutableMap(Iterable keys,
Iterable extends V2> values, int expectedSize) {
MutableQHashSeparateKVShortObjMapGO map = uninitializedMutableMap();
map.move(this.newUpdatableMap(keys, values, expectedSize));
return map;
}
@Override
@Nonnull
public HashShortObjMap newMutableMap(
Map map) {
MutableQHashSeparateKVShortObjMapGO res = uninitializedMutableMap();
res.move(this.newUpdatableMap(map));
return res;
}
@Override
@Nonnull
public HashShortObjMap newMutableMap(Map map1,
Map map2) {
MutableQHashSeparateKVShortObjMapGO res = uninitializedMutableMap();
res.move(this.newUpdatableMap(map1, map2));
return res;
}
@Override
@Nonnull
public HashShortObjMap newMutableMap(Map map1,
Map map2, Map map3) {
MutableQHashSeparateKVShortObjMapGO res = uninitializedMutableMap();
res.move(this.newUpdatableMap(map1, map2, map3));
return res;
}
@Override
@Nonnull
public HashShortObjMap newMutableMap(Map map1,
Map map2, Map map3,
Map map4) {
MutableQHashSeparateKVShortObjMapGO res = uninitializedMutableMap();
res.move(this.newUpdatableMap(map1, map2, map3, map4));
return res;
}
@Override
@Nonnull
public HashShortObjMap newMutableMap(Map map1,
Map map2, Map map3,
Map map4, Map map5) {
MutableQHashSeparateKVShortObjMapGO res = uninitializedMutableMap();
res.move(this.newUpdatableMap(map1, map2, map3, map4, map5));
return res;
}
@Override
@Nonnull
public HashShortObjMap newMutableMap(
Consumer> entriesSupplier
) {
MutableQHashSeparateKVShortObjMapGO map = uninitializedMutableMap();
map.move(this.newUpdatableMap(entriesSupplier));
return map;
}
@Override
@Nonnull
public HashShortObjMap newMutableMap(short[] keys,
V2[] values) {
MutableQHashSeparateKVShortObjMapGO map = uninitializedMutableMap();
map.move(this.newUpdatableMap(keys, values));
return map;
}
@Override
@Nonnull
public HashShortObjMap newMutableMap(
Short[] keys, V2[] values) {
MutableQHashSeparateKVShortObjMapGO map = uninitializedMutableMap();
map.move(this.newUpdatableMap(keys, values));
return map;
}
@Override
@Nonnull
public HashShortObjMap newMutableMap(Iterable keys,
Iterable extends V2> values) {
MutableQHashSeparateKVShortObjMapGO map = uninitializedMutableMap();
map.move(this.newUpdatableMap(keys, values));
return map;
}
@Override
@Nonnull
public HashShortObjMap newMutableMapOf(short k1, V2 v1) {
MutableQHashSeparateKVShortObjMapGO map = uninitializedMutableMap();
map.move(this.newUpdatableMapOf(k1, v1));
return map;
}
@Override
@Nonnull
public HashShortObjMap newMutableMapOf(short k1, V2 v1,
short k2, V2 v2) {
MutableQHashSeparateKVShortObjMapGO map = uninitializedMutableMap();
map.move(this.newUpdatableMapOf(k1, v1, k2, v2));
return map;
}
@Override
@Nonnull
public HashShortObjMap newMutableMapOf(short k1, V2 v1,
short k2, V2 v2, short k3, V2 v3) {
MutableQHashSeparateKVShortObjMapGO map = uninitializedMutableMap();
map.move(this.newUpdatableMapOf(k1, v1, k2, v2, k3, v3));
return map;
}
@Override
@Nonnull
public HashShortObjMap newMutableMapOf(short k1, V2 v1,
short k2, V2 v2, short k3, V2 v3,
short k4, V2 v4) {
MutableQHashSeparateKVShortObjMapGO map = uninitializedMutableMap();
map.move(this.newUpdatableMapOf(k1, v1, k2, v2, k3, v3, k4, v4));
return map;
}
@Override
@Nonnull
public HashShortObjMap newMutableMapOf(short k1, V2 v1,
short k2, V2 v2, short k3, V2 v3,
short k4, V2 v4, short k5, V2 v5) {
MutableQHashSeparateKVShortObjMapGO map = uninitializedMutableMap();
map.move(this.newUpdatableMapOf(k1, v1, k2, v2, k3, v3, k4, v4, k5, v5));
return map;
}
@Override
@Nonnull
public HashShortObjMap newImmutableMap(Map map1,
Map map2, int expectedSize) {
ImmutableQHashSeparateKVShortObjMapGO res = uninitializedImmutableMap();
res.move(this.newUpdatableMap(map1, map2, expectedSize));
return res;
}
@Override
@Nonnull
public HashShortObjMap newImmutableMap(Map