com.gs.collections.impl.multimap.list.FastListMultimap Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of gs-collections Show documentation
Show all versions of gs-collections Show documentation
GS Collections is a collections framework for Java. It has JDK-compatible List, Set and Map
implementations with a rich API and set of utility classes that work with any JDK compatible Collections,
Arrays, Maps or Strings. The iteration protocol was inspired by the Smalltalk collection framework.
/*
* Copyright 2011 Goldman Sachs.
*
* 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.gs.collections.impl.multimap.list;
import java.io.Externalizable;
import java.util.Collection;
import com.gs.collections.api.block.procedure.Procedure2;
import com.gs.collections.api.list.ImmutableList;
import com.gs.collections.api.list.MutableList;
import com.gs.collections.api.map.MutableMap;
import com.gs.collections.api.multimap.Multimap;
import com.gs.collections.api.multimap.list.ImmutableListMultimap;
import com.gs.collections.api.multimap.list.MutableListMultimap;
import com.gs.collections.api.tuple.Pair;
import com.gs.collections.impl.list.mutable.FastList;
import com.gs.collections.impl.map.mutable.UnifiedMap;
import com.gs.collections.impl.multimap.AbstractMutableMultimap;
public final class FastListMultimap
extends AbstractMutableMultimap>
implements MutableListMultimap, Externalizable
{
private static final long serialVersionUID = 1L;
// Default from FastList
private static final int DEFAULT_CAPACITY = 1;
private int initialListCapacity;
public FastListMultimap()
{
this.initialListCapacity = DEFAULT_CAPACITY;
}
public FastListMultimap(int distinctKeys, int valuesPerKey)
{
super(Math.max(distinctKeys * 2, 16));
if (distinctKeys < 0 || valuesPerKey < 0)
{
throw new IllegalArgumentException("Both arguments must be positive.");
}
this.initialListCapacity = valuesPerKey;
}
public FastListMultimap(Multimap extends K, ? extends V> multimap)
{
this(
multimap.keysView().size(),
multimap instanceof FastListMultimap
? ((FastListMultimap, ?>) multimap).initialListCapacity
: DEFAULT_CAPACITY);
this.putAll(multimap);
}
public FastListMultimap(Pair... pairs)
{
super(pairs);
}
public static FastListMultimap newMultimap()
{
return new FastListMultimap();
}
public static FastListMultimap newMultimap(Multimap extends K, ? extends V> multimap)
{
return new FastListMultimap(multimap);
}
public static FastListMultimap newMultimap(Pair... pairs)
{
return new FastListMultimap(pairs);
}
@Override
protected MutableMap> createMap()
{
return UnifiedMap.newMap();
}
@Override
protected MutableMap> createMapWithKeyCount(int keyCount)
{
return UnifiedMap.newMap(keyCount);
}
@Override
protected MutableList createCollection()
{
return FastList.newList(this.initialListCapacity);
}
public void trimToSize()
{
for (Collection collection : this.map.values())
{
FastList fastList = (FastList) collection;
fastList.trimToSize();
}
}
public FastListMultimap newEmpty()
{
return new FastListMultimap();
}
public MutableListMultimap toMutable()
{
return new FastListMultimap(this);
}
public ImmutableListMultimap toImmutable()
{
final MutableMap> map = UnifiedMap.newMap();
this.map.forEachKeyValue(new Procedure2>()
{
public void value(K key, MutableList list)
{
map.put(key, list.toImmutable());
}
});
return new ImmutableListMultimapImpl(map);
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy