ReferenceManager

abstract class ReferenceManager<G> : AutoCloseable

Utility class to safely share instances of a certain type across multiple threads, while periodically refreshing them. This class ensures each reference is closed only once all threads have finished using it. It is recommended to consult the documentation of ReferenceManager implementations for their maybeRefresh semantics.

Type Parameters

G

the concrete type that will be acquire acquired and release released.

Inheritors

Constructors

Link copied to clipboard
constructor()

Types

Link copied to clipboard
object Companion
Link copied to clipboard
interface RefreshListener

Functions

Link copied to clipboard
fun acquire(): G

Obtain the current reference. You must match every call to acquire with one call to release; it's best to do so in a finally clause, and set the reference to null to prevent accidental usage after it has been released.

Link copied to clipboard

Adds a listener, to be notified when a reference is refreshed/swapped.

Link copied to clipboard
open override fun close()

Closes this ReferenceManager to prevent future acquire acquiring. A reference manager should be closed if the reference to the managed resource should be disposed or the application using the ReferenceManager is shutting down. The managed resource might not be released immediately, if the ReferenceManager user is holding on to a previously acquire acquired reference. The resource will be released once when the last reference is release released. Those references can still be used as if the manager was still active.

Link copied to clipboard

You must call this (or maybeRefreshBlocking), periodically, if you want that will return refreshed instances.

Link copied to clipboard

You must call this (or maybeRefresh), periodically, if you want that will return refreshed instances.

Link copied to clipboard
fun release(reference: G)

Release the reference previously obtained via acquire.

Link copied to clipboard

Removes a listener added by addListener.