summaryrefslogtreecommitdiff
path: root/test/files/run/ctries/DumbHash.scala
diff options
context:
space:
mode:
authorAleksandar Prokopec <axel22@gmail.com>2012-02-01 19:54:50 +0100
committerAleksandar Prokopec <axel22@gmail.com>2012-02-01 19:54:50 +0100
commit5fe2d8b109abf3ff3e2d82dd4f248200846795c3 (patch)
treeb50c45368759198fdcd0521016138a3fd7019322 /test/files/run/ctries/DumbHash.scala
parent8aa87f15e3887dbeb1a39bfea002b56cf68c445a (diff)
downloadscala-5fe2d8b109abf3ff3e2d82dd4f248200846795c3.tar.gz
scala-5fe2d8b109abf3ff3e2d82dd4f248200846795c3.tar.bz2
scala-5fe2d8b109abf3ff3e2d82dd4f248200846795c3.zip
Add the Ctrie concurrent map implementation.
Ctrie is a scalable concurrent map implementation that supports constant time lock-free lazy snapshots. Due to the well-known private volatile field problem, atomic reference updaters cannot be used efficiently in Scala yet. For this reason, 4 java files had to be included as well. None of these pollute the namespace, as most of the classes are private. Unit tests and a scalacheck check is also included.
Diffstat (limited to 'test/files/run/ctries/DumbHash.scala')
-rw-r--r--test/files/run/ctries/DumbHash.scala14
1 files changed, 14 insertions, 0 deletions
diff --git a/test/files/run/ctries/DumbHash.scala b/test/files/run/ctries/DumbHash.scala
new file mode 100644
index 0000000000..8ef325b67c
--- /dev/null
+++ b/test/files/run/ctries/DumbHash.scala
@@ -0,0 +1,14 @@
+
+
+
+
+
+
+class DumbHash(val i: Int) {
+ override def equals(other: Any) = other match {
+ case that: DumbHash => that.i == this.i
+ case _ => false
+ }
+ override def hashCode = i % 5
+ override def toString = "DH(%s)".format(i)
+}