Is there any difference in a persistent and immutable data structure? Wikipedia refers to immutable data structure when discussing persistence but I have a feeling there might be a subtle difference between the two.
问题:
回答1:
Immutability is an implementation technique. Among other things, it provides persistence, which is an interface. The persistence API is something like:
version update(operation o, version v)
performs operationo
on versionv
, returning a new version. If the data structure is immutable, the new version is a new structure (that may share immutable parts of the old structure). If the data structure isn't immutable, the returned version might just be a version number. The versionv
remains a valid version, and it shouldn't change in anyobserve
-able way because of this update - the update is only visible in the returned version, not inv
.data observe(query q, version v)
observes a data structure at versionv
without changing it or creating a new version.
For more about these differences, see:
- The chapter "Persistent data structures" by Haim Kaplan in Handbook on Data Structures and Applications
- "Making Data Structures Persistent" by Driscoll et al.
- The first lecture of the Spring 2012 incarnation of MIT's 6.851: Advanced Data Structures
回答2:
Yes, there is a difference. An immutable data structure cannot be modified in any way after its creation. The only way to effective modify it would be to make a mutable copy or something similar (e.g. slightly modifying the parameters you pass to the constructor of the new one). A persistent data structure, on the other hand, is mutable in the sense that the exposed API appears to allow changes to the data structure. In truth, though, any changes will retain a pointer to the existing data structure (and therefore every preceding structure); they only seem to mutate the data structure because the exposed API returns a new pointer that may include pointers to a subset of the previous data structure (in trees, e.g., we will point at the node whose subtree hasn't changed as a result of the operation).