genstack

package
v2.2.2 Latest Latest
Warning

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

Go to latest
Published: May 16, 2025 License: MIT Imports: 0 Imported by: 0

Documentation

Index

Constants

This section is empty.

Variables

This section is empty.

Functions

This section is empty.

Types

type GenStack

type GenStack[T any] struct {
	// contains filtered or unexported fields
}

GenStack implements a generational stack.

GenStack works as common stack except for the fact that all elements in the older generation are guaranteed to be popped before any element in the newer generation. New elements are always pushed to the current (newest) generation.

We could also say that GenStack behaves as a stack in case of a single generation, but it behaves as a queue of individual generation stacks.

func NewGenStack

func NewGenStack[T any]() *GenStack[T]

NewGenStack creates a new empty GenStack.

func (*GenStack[T]) Len

func (s *GenStack[T]) Len() int

Len returns number of elements in the stack.

func (*GenStack[T]) NextGen

func (s *GenStack[T]) NextGen()

NextGen starts a new stack generation.

func (*GenStack[T]) Pop

func (s *GenStack[T]) Pop() (T, bool)

func (*GenStack[T]) Push

func (s *GenStack[T]) Push(v T)

Push pushes a new element at the top of the stack.

Jump to

Keyboard shortcuts

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