hashbidimap

package
v0.10.4 Latest Latest
Warning

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

Go to latest
Published: Apr 26, 2023 License: BSD-2-Clause, ISC Imports: 5 Imported by: 0

Documentation

Overview

Package hashbidimap implements a bidirectional map backed by two hashmaps.

A bidirectional map, or hash bag, is an associative data structure in which the (key,value) pairs form a one-to-one correspondence. Thus the binary relation is functional in each direction: value can also act as a key to key. A pair (a,b) thus provides a unique coupling between 'a' and 'b' so that 'b' can be found when 'a' is used as a key and 'a' can be found when 'b' is used as a key.

Elements are unordered in the map.

Structure is not thread safe.

Reference: https://en.wikipedia.org/wiki/Bidirectional_map

Index

Constants

This section is empty.

Variables

This section is empty.

Functions

This section is empty.

Types

type Map

type Map[K, T comparable] struct {
	// contains filtered or unexported fields
}

Map holds the elements in two hashmaps.

func New

func New[K, T comparable]() *Map[K, T]

New instantiates a bidirectional map.

func (*Map[K, T]) Clear

func (m *Map[K, T]) Clear()

Clear removes all elements from the map.

func (*Map[K, T]) Empty

func (m *Map[K, T]) Empty() bool

Empty returns true if map does not contain any elements

func (*Map[K, T]) FromJSON

func (m *Map[K, T]) FromJSON(data []byte) error

FromJSON populates the map from the input JSON representation.

func (*Map[K, T]) Get

func (m *Map[K, T]) Get(key K) (value T, found bool)

Get searches the element in the map by key and returns its value or nil if key is not found in map. Second return parameter is true if key was found, otherwise false.

func (*Map[K, T]) GetKey

func (m *Map[K, T]) GetKey(value T) (key K, found bool)

GetKey searches the element in the map by value and returns its key or nil if value is not found in map. Second return parameter is true if value was found, otherwise false.

func (*Map[K, T]) Keys

func (m *Map[K, T]) Keys() []K

Keys returns all keys (random order).

func (*Map[K, T]) MarshalJSON

func (m *Map[K, T]) MarshalJSON() ([]byte, error)

MarshalJSON @implements json.Marshaler

func (*Map[K, T]) Put

func (m *Map[K, T]) Put(key K, value T)

Put inserts element into the map.

func (*Map[K, T]) Remove

func (m *Map[K, T]) Remove(key K)

Remove removes the element from the map by key.

func (*Map[K, T]) Size

func (m *Map[K, T]) Size() int

Size returns number of elements in the map.

func (*Map[K, T]) String

func (m *Map[K, T]) String() string

String returns a string representation of container

func (*Map[K, T]) ToJSON

func (m *Map[K, T]) ToJSON() ([]byte, error)

ToJSON outputs the JSON representation of the map.

func (*Map[K, T]) UnmarshalJSON

func (m *Map[K, T]) UnmarshalJSON(bytes []byte) error

UnmarshalJSON @implements json.Unmarshaler

func (*Map[K, T]) Values

func (m *Map[K, T]) Values() []T

Values returns all values (random order).

Jump to

Keyboard shortcuts

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