Package ubic.basecode.dataStructure
Class CountingMap<K>
java.lang.Object
ubic.basecode.dataStructure.CountingMap<K>
- Type Parameters:
- K-
Convenience Map that has a count as the value for each key. Calling increment(K key) increases the count for
 key.
 
This replaces the idiom of map.containsKey(k) ? map.put(k, map.get(k) + 1) : map.put(k, 0);
- Author:
- luke
- 
Nested Class Summary
- 
Constructor SummaryConstructorsConstructorDescriptionConstructs a CountingMap backed by a simple HashMap.CountingMap(Map<K, Integer> map) Constructs a CountingMap backed by the specified Map.
- 
Method SummaryModifier and TypeMethodDescriptionvoidclear()booleancontainsKey(Object key) booleancontainsValue(Object value) intReturns the count associated with the specified key, or zero if the key has never been incremented.entrySet()booleaninthashCode()intIncrements the count associated with the specified key and returns the incremented count.voidincrementAll(Collection<K> keys) Increments the count associated with the specified keys.booleanisEmpty()keySet()intmax()voidbooleanReturns true if the specified key has ever been incremented, false otherwise.intsize()Returns a list of the keys in this map, sorted by ascending count.sortedKeyList(boolean sortDescending) Returns a list of the keys in this map, sorted as specified.toString()inttotal()Returns the sum of all counts in the map.values()Methods inherited from class java.lang.Objectclone, finalize, getClass, notify, notifyAll, wait, wait, waitMethods inherited from interface java.util.Mapcompute, computeIfAbsent, computeIfPresent, forEach, getOrDefault, merge, putIfAbsent, remove, replace, replace, replaceAll
- 
Constructor Details- 
CountingMappublic CountingMap()Constructs a CountingMap backed by a simple HashMap.
- 
CountingMapConstructs a CountingMap backed by the specified Map.- Parameters:
- map- the backing Map
 
 
- 
- 
Method Details- 
clearpublic void clear()
- 
containsKey- Specified by:
- containsKeyin interface- Map<K,- Integer> 
 
- 
containsValue- Specified by:
- containsValuein interface- Map<K,- Integer> 
 
- 
countReturns the count associated with the specified key, or zero if the key has never been incremented.- Parameters:
- key- the key whose associated count is to be returned
- Returns:
- the count associated with the specified key, or zero if the key has never been incremented
 
- 
entrySet
- 
equals
- 
get
- 
hashCodepublic int hashCode()
- 
incrementIncrements the count associated with the specified key and returns the incremented count. If the key doesn't already exist in the map, it will be added.- Parameters:
- key- the key whose associated count is to be incremented
- Returns:
- the incremented value associated with the specified key
 
- 
incrementAllIncrements the count associated with the specified keys. If a key doesn't already exist in the map, it will be added.- Parameters:
- keys- the keys whose associated count is to be incremented
 
- 
isEmptypublic boolean isEmpty()
- 
keySet
- 
maxpublic int max()- Returns:
 
- 
put
- 
putAll
- 
remove
- 
seenReturns true if the specified key has ever been incremented, false otherwise.- Parameters:
- key- the key whose presence is to be tested
- Returns:
- true if the specified key has ever been incremented, false otherwise
 
- 
sizepublic int size()
- 
sortedKeyListReturns a list of the keys in this map, sorted by ascending count.- Returns:
- a list of the keys in this map, sorted by ascending count
 
- 
sortedKeyListReturns a list of the keys in this map, sorted as specified.- Parameters:
- sortDescending- true to sort by descending count, false to sort by ascending count
- Returns:
- a list of the keys in this map, sorted as specified.
 
- 
toString
- 
totalpublic int total()Returns the sum of all counts in the map.
- 
values
 
-