Scala Library: scala.collection.concurrent
scala.collection.concurrent
package concurrent
Type Members
trait Map[A, B] extends mutable.Map[A, B]
A template trait for mutable maps that allow concurrent access.
This is a base trait for all Scala concurrent map implementations. It provides
all of the methods a Map
does, with the difference that all the changes are
atomic. It also describes methods specific to concurrent maps.
Note : The concurrent maps do not accept null
for keys or values.
- A
- the key type of the map
- B
- the value type of the map
- Source
- Since
- 2.8
- See also
- “Scala’s Collection Library overview”
section on
Concurrent Maps
for more information.
- “Scala’s Collection Library overview”
section on
final class TrieMap[K, V] extends Map[K, V] with mutable.MapLike[K, V, TrieMap[K, V]] with CustomParallelizable[(K, V), ParTrieMap[K, V]] with Serializable
A concurrent hash-trie or TrieMap is a concurrent thread-safe lock-free implementation of a hash array mapped trie. It is used to implement the concurrent map abstraction. It has particularly scalable concurrent insert and remove operations and is memory-efficient. It supports O(1), atomic, lock-free snapshots which are used to implement linearizable lock-free size, iterator and clear operations. The cost of evaluating the (lazy) snapshot is distributed across subsequent updates, thus making snapshot evaluation horizontally scalable.
For details, see: http://lampwww.epfl.ch/~prokopec/ctries-snapshot.pdf
- Annotations
- @ SerialVersionUID ()
- Source
- Since
- 2.10
Value Members
object TrieMap extends MutableMapFactory[TrieMap] with Serializable
Full Source:
/* __ *\
** ________ ___ / / ___ Scala API **
** / __/ __// _ | / / / _ | (c) 2010-2013, LAMP/EPFL **
** __\ \/ /__/ __ |/ /__/ __ | http://scala-lang.org/ **
** /____/\___/_/ |_/____/_/ | | **
** |/ **
\* */
package scala
package collection.concurrent
/** A template trait for mutable maps that allow concurrent access.
*
* $concurrentmapinfo
*
* @since 2.8
* @see [[http://docs.scala-lang.org/overviews/collections/concrete-mutable-collection-classes.html#concurrent_maps "Scala's Collection Library overview"]]
* section on `Concurrent Maps` for more information.
*
* @tparam A the key type of the map
* @tparam B the value type of the map
*
* @define Coll `concurrent.Map`
* @define coll concurrent map
* @define concurrentmapinfo
* This is a base trait for all Scala concurrent map implementations. It
* provides all of the methods a `Map` does, with the difference that all the
* changes are atomic. It also describes methods specific to concurrent maps.
*
* '''Note''': The concurrent maps do not accept `'''null'''` for keys or values.
*
* @define atomicop
* This is an atomic operation.
*/
trait Map[A, B] extends scala.collection.mutable.Map[A, B] {
/**
* Associates the given key with a given value, unless the key was already
* associated with some other value.
*
* $atomicop
*
* @param k key with which the specified value is to be associated with
* @param v value to be associated with the specified key
* @return `Some(oldvalue)` if there was a value `oldvalue` previously
* associated with the specified key, or `None` if there was no
* mapping for the specified key
*/
def putIfAbsent(k: A, v: B): Option[B]
/**
* Removes the entry for the specified key if it's currently mapped to the
* specified value.
*
* $atomicop
*
* @param k key for which the entry should be removed
* @param v value expected to be associated with the specified key if
* the removal is to take place
* @return `true` if the removal took place, `false` otherwise
*/
def remove(k: A, v: B): Boolean
/**
* Replaces the entry for the given key only if it was previously mapped to
* a given value.
*
* $atomicop
*
* @param k key for which the entry should be replaced
* @param oldvalue value expected to be associated with the specified key
* if replacing is to happen
* @param newvalue value to be associated with the specified key
* @return `true` if the entry was replaced, `false` otherwise
*/
def replace(k: A, oldvalue: B, newvalue: B): Boolean
/**
* Replaces the entry for the given key only if it was previously mapped
* to some value.
*
* $atomicop
*
* @param k key for which the entry should be replaced
* @param v value to be associated with the specified key
* @return `Some(v)` if the given key was previously mapped to some value `v`, or `None` otherwise
*/
def replace(k: A, v: B): Option[B]
override def getOrElseUpdate(key: A, op: =>B): B = get(key) match {
case Some(v) => v
case None =>
val v = op
putIfAbsent(key, v) match {
case Some(nv) => nv
case None => v
}
}
}
Interested in Scala?
I send out weekly, personalized emails with articles and conference talks.
Subscribe now.