com.sangupta.jerry.ds.SimpleMultiMap Maven / Gradle / Ivy
/**
*
* jerry - Common Java Functionality
* Copyright (c) 2012-2015, Sandeep Gupta
*
* http://sangupta.com/projects/jerry
*
* 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.sangupta.jerry.ds;
import java.util.ArrayList;
import java.util.List;
import java.util.Map;
import java.util.Set;
import java.util.concurrent.ConcurrentHashMap;
import java.util.concurrent.ConcurrentMap;
/**
* A very simple implementation of a Multi-Map for use that does not implement
* the {@link Map} interface. It is useful for situations where a very
* light-weight implementation is needed, for collecting and iterating over
* multiple objects that map to same key.
*
* This implementation is based on {@link ConcurrentHashMap}. For more advanced
* implementations see Google Guava library.
*
* The implementation is not thread-safe multiple threads are adding values for
* a key that is also being removed.
*
* @author sangupta
*
*/
public class SimpleMultiMap {
/**
* The backing {@link ConcurrentHashMap}
*/
private final ConcurrentMap> map = new ConcurrentHashMap>();
/**
* Return the number of keys stored in the map.
*
* @return the size of map
*/
public int size() {
return this.map.size();
}
/**
* Check if there are any keys stored in this map or not
*
* @return true
if no keys are present, false
* otherwise
*/
public boolean isEmpty() {
return this.map.isEmpty();
}
/**
* Check if the given key is present in the map or not
*
* @param key
* the key being looked for
*
* @return true
if key is present, false
otherwise
*/
public boolean containsKey(K key) {
return this.map.containsKey(key);
}
/**
* Return the list of all values stored against the key
*
* @param key
* the key being looked for
*
* @return the list of all values, null
otherwise
*/
public List getValues(K key) {
return this.map.get(key);
}
/**
* Store the given value object against the key.
*
* @param key
* the key for mapping
*
* @param value
* the value to be stored
*/
public void put(K key, V value) {
List values;
if(this.map.containsKey(key)) {
values = this.map.get(key);
if(values != null) {
values.add(value);
return;
}
}
// no value
values = new ArrayList();
values.add(value);
values = this.map.putIfAbsent(key, values);
if(values == null) {
// added successfully
return;
}
values.add(value);
}
/**
* Remove and return all values associated with the given key.
*
* @param key
* the key to remove
*
* @return the list of values stored against the removed key
*/
public List remove(K key) {
return this.map.remove(key);
}
/**
* Return a {@link Set} of all keys in this map.
*
* @return all the keys in the map
*/
public Set keySet() {
return this.map.keySet();
}
/**
* Clear all keys from this map.
*
*/
public void clear() {
this.map.clear();
}
@Override
public int hashCode() {
return this.map.hashCode();
}
@Override
public boolean equals(Object obj) {
return this.map.equals(obj);
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy