Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/hrldcpr/pcollections
A Persistent Java Collections Library
https://github.com/hrldcpr/pcollections
Last synced: 2 months ago
JSON representation
A Persistent Java Collections Library
- Host: GitHub
- URL: https://github.com/hrldcpr/pcollections
- Owner: hrldcpr
- License: other
- Created: 2014-03-20T09:28:01.000Z (almost 11 years ago)
- Default Branch: master
- Last Pushed: 2024-03-17T22:04:34.000Z (10 months ago)
- Last Synced: 2024-08-01T18:24:42.612Z (5 months ago)
- Language: Java
- Size: 2.53 MB
- Stars: 760
- Watchers: 32
- Forks: 79
- Open Issues: 17
-
Metadata Files:
- Readme: README.md
- Changelog: CHANGELOG.md
- License: LICENSE
Awesome Lists containing this project
- awesome-java - Persistent Collection - Persistent and immutable analogue of the Java Collections Framework. (Projects / Data Structures)
- awesome-java-zh - Persistent Collection - Java集合框架的持久和不可变的模拟。 (项目 / 数据结构)
- awesome-java - Persistent Collection - Persistent and immutable analogue of the Java Collections Framework. (Projects / Data Structures)
README
# PCollections
A Persistent Java Collections Library
[![Maven Central](https://img.shields.io/maven-central/v/org.pcollections/pcollections.svg)](https://mvnrepository.com/artifact/org.pcollections/pcollections/latest)
[![Javadoc](https://www.javadoc.io/badge/org.pcollections/pcollections.svg)](https://javadoc.io/doc/org.pcollections/pcollections/latest/org.pcollections/org/pcollections/package-summary.html)### Overview
PCollections serves as a [persistent](https://en.wikipedia.org/wiki/Persistent_data_structure) and immutable analogue of the Java Collections Framework. This includes **efficient**, **thread-safe**, **generic**, **immutable**, and **persistent** stacks, maps, vectors, sets, and bags, **compatible** with their Java Collections counterparts.
Persistent and immutable datatypes are increasingly appreciated as a **simple**, **design-friendly**, **concurrency-friendly**, and sometimes more time- and space-efficient alternative to mutable datatypes.
### Persistent versus Unmodifiable
Note that these immutable collections are very different from the immutable collections returned by Java's [Collections.unmodifiableCollection()]() and similar methods. The difference is that Java's unmodifiable collections have no producers, whereas PCollections have very efficient producers.
Thus if you have an unmodifiable Collection `x` and you want a new Collection `x2` consisting of the elements of `x` in addition to some element `e`, you would have to do something like:
```Java
Collection x2 = new HashSet(x);
x2.add(e);
```which involves copying all of `x`, using linear time and space.
If, on the other hand, you have a PCollection `y` you can simply say:
```Java
PCollection y2 = y.plus(e);
```which still leaves `y` untouched but generally requires little or no copying, using time and space much more efficiently.
### Usage
PCollections are created using producers and static factory methods. Some example static factory methods are [`HashTreePSet.empty()`]() which returns an empty [PSet](https://javadoc.io/doc/org.pcollections/pcollections/latest/org.pcollections/org/pcollections/PSet.html), while `HashTreePSet.singleton(e)` returns a PSet containing just the element `e`, and `HashTreePSet.from(collection)` returns a PSet containing the same elements as `collection`. See [Example Code](#example-code) below for an example of using producers.
The same `empty()`, `singleton()`, and `from()` factory methods are found in each of the PCollections implementations, which currently include one concrete implementation for each abstract type:
- [HashTreePMap](https://javadoc.io/doc/org.pcollections/pcollections/latest/org.pcollections/org/pcollections/HashTreePMap.html) provides a [PMap](https://javadoc.io/doc/org.pcollections/pcollections/latest/org.pcollections/org/pcollections/PMap.html) implementation, analogous to Java's HashMap.
- [TreePMap](https://javadoc.io/doc/org.pcollections/pcollections/latest/org.pcollections/org/pcollections/TreePMap.html) provides a
[PSortedMap](https://javadoc.io/doc/org.pcollections/pcollections/latest/org.pcollections/org/pcollections/PSortedMap.html) implementation,
analogous to Java's TreeMap.
- [ConsPStack](https://javadoc.io/doc/org.pcollections/pcollections/latest/org.pcollections/org/pcollections/ConsPStack.html) provides a [PStack](https://javadoc.io/doc/org.pcollections/pcollections/latest/org.pcollections/org/pcollections/PStack.html) implementation, analogous to Java's LinkedList.
- [TreePVector](https://javadoc.io/doc/org.pcollections/pcollections/latest/org.pcollections/org/pcollections/TreePVector.html) provides a [PVector](https://javadoc.io/doc/org.pcollections/pcollections/latest/org.pcollections/org/pcollections/PVector.html) implementation, analogous to Java's ArrayList.
- [HashTreePSet](https://javadoc.io/doc/org.pcollections/pcollections/latest/org.pcollections/org/pcollections/HashTreePSet.html) provides a [PSet](https://javadoc.io/doc/org.pcollections/pcollections/latest/org.pcollections/org/pcollections/PSet.html) implementation, analogous to Java's HashSet.
- [TreePSet](https://javadoc.io/doc/org.pcollections/pcollections/latest/org.pcollections/org/pcollections/TreePSet.html) provides a
[PSortedSet](https://javadoc.io/doc/org.pcollections/pcollections/latest/org.pcollections/org/pcollections/PSortedSet.html) implementation,
analogous to Java's TreeSet.
- [HashTreePBag](https://javadoc.io/doc/org.pcollections/pcollections/latest/org.pcollections/org/pcollections/HashTreePBag.html) provides a [PBag](https://javadoc.io/doc/org.pcollections/pcollections/latest/org.pcollections/org/pcollections/PBag.html) implementation, which is unordered like a set but can contain duplicate elements.PCollections are highly interoperable with Java Collections:
- Every PCollection is a java.util.Collection.
- Every PMap is a java.util.Map.
- Every PSequence is a java.util.List.
- This includes every PStack and every PVector.
- Every PSet is a java.util.Set.
- Every PSortedMap is a java.util.SortedMap and java.util.NavigableMap.
- Every PSortedSet is a java.util.SortedSet and java.util.NavigableSet.PCollections uses [Semantic Versioning](https://semver.org/), which establishes a strong correspondence between API changes and version numbering.
PCollections is in the [Maven Central repository](https://search.maven.org/search?q=g:org.pcollections), under org.pcollections. Thus the Maven coordinates for PCollections are:
```xml
org.pcollections
pcollections
4.0.2```
or Gradle:
```groovy
compile 'org.pcollections:pcollections:4.0.2'
```### Example Code
The following gives a very simple example of using PCollections, including the static factory method HashTreePSet.empty() and the producer plus(e):
```Java
import org.pcollections.*;public class Example {
public static void main(String... args) {
PSet set = HashTreePSet.empty();
set = set.plus("something");System.out.println(set);
System.out.println(set.plus("something else"));
System.out.println(set);
}
}
```Running this program gives the following output:
```
[something]
[something else, something]
[something]
```### Building from source
To build the project from source [clone the repository](https://github.com/hrldcpr/pcollections) and then run `./gradlew`
### Related Work
[Clojure](https://clojure.org/reference/data_structures), [Scala](https://docs.scala-lang.org/overviews/collections-2.13/introduction.html), and [kotlinx.collections.immutable](https://github.com/Kotlin/kotlinx.collections.immutable) also provide persistent collections on the JVM, but they are less interoperable with Java. Both [Guava](https://guava.dev/releases/19.0/api/docs/com/google/common/collect/ImmutableCollection.html) and [java.util.Collections]() provide immutable collections but they are not persistent—that is, they do not provide efficient producers—so they are not nearly as useful. See [Persistent versus Unmodifiable](#persistent-versus-unmodifiable) above.