finalized

package
v0.19.0 Latest Latest
Warning

This package is not in the latest version of its module.

Go to latest
Published: Dec 16, 2024 License: Apache-2.0 Imports: 3 Imported by: 0

Documentation

Overview

Package finalized provided a view management for a backend object, which is based on Go Garbage Collection and runtime finalizers. Finalization is not possible in Go, if an object is involved in a reference cycle. In such a case the complete cycle is not garbage collected at all.

If some kind of finalization is required together with cyclic object dependencies, the cleanup of the object can therefore not be done with runtime finalizers. We separate a garbage collectable view object, which holds a reference to a backend object featuring cycles. The view object uses reference counting for its backend together with runtime finalization. Therefore, it does not require a Close method. If the view is garbage collected it releases its reference to the backend object. If the last view vanished the cleanup method for the backend object is called.

The object functionality is exposed via an interface, only, which is also implemented by the vies by embedding a pointer to the backend object.

If the backend object requires a cycle by holding local objects requiring a reference to the object, this can be done by NOT using view objects for this cycle, but the backend object itself. If the local object wants to pass the backend object to some outgoing call, it MUST wrap the backend object again into a new view. Therefore, objects involved in the cycle MUST be prepared to handle such outgoing references.

Index

Constants

This section is empty.

Variables

This section is empty.

Functions

This section is empty.

Types

type FinalizedRef

type FinalizedRef struct {
	// contains filtered or unexported fields
}

func NewPlainFinalizedView

func NewPlainFinalizedView(allocatable refmgmt.Allocatable) (*FinalizedRef, error)

func (*FinalizedRef) GetAllocatable

func (v *FinalizedRef) GetAllocatable() refmgmt.Allocatable

func (*FinalizedRef) GetRefId

Jump to

Keyboard shortcuts

? : This menu
/ : Search site
f or F : Jump to
y or Y : Canonical URL