coll

package
v0.0.0-...-6bbb419 Latest Latest
Warning

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

Go to latest
Published: Jan 5, 2025 License: Apache-2.0 Imports: 6 Imported by: 0

Documentation

Index

Constants

This section is empty.

Variables

This section is empty.

Functions

func AddAt

func AddAt[T comparable](src []T, index int, ele T) []T

func BatchConsume

func BatchConsume[T comparable](list []T, batchSize int, consumer func([]T))

BatchConsume 分批处理,每batchSize一批

func Contains

func Contains[T comparable](list []T, ele T) bool

func ContainsIgnoreCase

func ContainsIgnoreCase(slice []string, ele string) bool

func ContainsIgnoreCaseReturnEle

func ContainsIgnoreCaseReturnEle(slice []string, ele string) (bool, string)

func ConvertEle

func ConvertEle[T any, R any](ts []T, t2r func(t T) R) []R

func Distinct

func Distinct[T comparable](list []T) []T

Distinct 去重

func Page

func Page[T comparable](list []T, subSize int) [][]T

Page 根据subSize分页

func Remove

func Remove[T comparable](src []T, ele T) []T

func RemoveAt

func RemoveAt[T comparable](src []T, index int) []T

Types

type Collection

type Collection[E comparable] interface {

	// Add 向集合中添加一个元素ele
	Add(ele E)

	// Remove 移除集合中的一个元素ele
	Remove(ele E) bool

	// Size 返回集合的长度
	Size() int

	// Contains 判断集合中是否包含元素ele
	Contains(ele E) bool

	// IsEmpty 判断集合是否为空集合
	IsEmpty() bool

	// Stream 转为streams.Stream[T]接口
	Stream() streams.Stream[E]

	// ForEach for循环
	ForEach(f func(e E))
}

type List

type List[E comparable] []E

List 切片的别名

func NewList

func NewList[E comparable]() *List[E]

NewList 创建list集合

func NewList4Set

func NewList4Set[E comparable](keyMap map[E]struct{}) *List[E]

NewList4Set 根据keyMap创建*List[E]

func NewListWithCap

func NewListWithCap[E comparable](cap int) *List[E]

NewListWithCap 创建list集合, 可设置 cap容量

func OfList

func OfList[E comparable](slice []E) *List[E]

OfList 将切片slice转成*List[E]

func (*List[E]) Add

func (my *List[E]) Add(ele E)

Add 在切片末尾添加一个元素ele

func (*List[E]) AddAll

func (my *List[E]) AddAll(eles []E)

AddAll 在切片末尾添加len(eles)个元素eles

func (*List[E]) AddAllAt

func (my *List[E]) AddAllAt(index int, eles []E)

AddAllAt 从切片index索引位置开始添加len(eles)个元素eles

func (*List[E]) AddAt

func (my *List[E]) AddAt(index int, ele E)

AddAt 在切片index索引位置添加一个元素ele

func (*List[E]) Contains

func (my *List[E]) Contains(ele E) bool

Contains 返回切片是否包含元素ele的布尔值

func (*List[E]) ForEach

func (my *List[E]) ForEach(action func(t E))

ForEach 切片的循环操作

func (*List[E]) Get

func (my *List[E]) Get(index int) E

Get 返回切片索引index处的元素

func (*List[E]) IndexOf

func (my *List[E]) IndexOf(ele E) int

IndexOf 返回ele对应切片最近一个元素的索引下标,没有则返回-1

func (*List[E]) IsEmpty

func (my *List[E]) IsEmpty() bool

IsEmpty 返回切片是否为空的布尔值

func (*List[E]) LastIndexOf

func (my *List[E]) LastIndexOf(ele E) int

LastIndexOf 返回ele对应切片最后一个元素的索引下标,没有则返回-1

func (*List[E]) Lists

func (my *List[E]) Lists(subSize int) [][]E

Lists 返回切片的子切片的切片(子切片大小为subSize)

func (*List[E]) Remove

func (my *List[E]) Remove(ele E) bool

Remove 删除切片中的元素ele

func (*List[E]) RemoveAll

func (my *List[E]) RemoveAll(eles []E)

RemoveAll 删除切片中的元素eles

func (*List[E]) RemoveAt

func (my *List[E]) RemoveAt(index int) bool

RemoveAt 删除切片index索引位置的元素

func (*List[E]) RemoveIf

func (my *List[E]) RemoveIf(predicate func(ele E) bool)

RemoveIf 删除表达式predicate为true的切片中的元素

func (*List[E]) RetainAll

func (my *List[E]) RetainAll(eles []E)

RetainAll 保留切片中的元素eles

func (*List[E]) Size

func (my *List[E]) Size() int

Size 返回切片的大小

func (*List[E]) Stream

func (my *List[E]) Stream() streams.Stream[E]

Stream 将List转化为Stream流处理

func (*List[E]) ToSet

func (my *List[E]) ToSet() *Set[E]

ToSet list转set

type Map

type Map[K comparable, V any] map[K]V

func NewMap

func NewMap[K comparable, V any]() *Map[K, V]

func NewMapWithCap

func NewMapWithCap[K comparable, V any](cap int) *Map[K, V]

func OfMap

func OfMap[K comparable, V any](m map[K]V) *Map[K, V]

func (*Map[K, V]) ContainsKey

func (my *Map[K, V]) ContainsKey(key K) bool

func (*Map[K, V]) Entries

func (my *Map[K, V]) Entries() []MapNode[K, V]

func (*Map[K, V]) ForEach

func (my *Map[K, V]) ForEach(action func(key K, val V))

func (*Map[K, V]) Get

func (my *Map[K, V]) Get(key K) (V, bool)

func (*Map[K, V]) IsEmpty

func (my *Map[K, V]) IsEmpty() bool

func (*Map[K, V]) Keys

func (my *Map[K, V]) Keys() []K

func (*Map[K, V]) Put

func (my *Map[K, V]) Put(key K, val V)

func (*Map[K, V]) Remove

func (my *Map[K, V]) Remove(key K)

func (*Map[K, V]) Size

func (my *Map[K, V]) Size() int

func (*Map[K, V]) Stream

func (my *Map[K, V]) Stream() streams.Stream[MapNode[K, V]]

func (*Map[K, V]) Values

func (my *Map[K, V]) Values() []V

type MapNode

type MapNode[K comparable, V any] struct {
	Key   K
	Value V
}

type Set

type Set[E comparable] map[E]struct{}

func NewSet

func NewSet[E comparable]() *Set[E]

NewSet 创建一个set集合

func NewSet4Slice

func NewSet4Slice[E comparable](slice []E) *Set[E]

func NewSetWithCap

func NewSetWithCap[E comparable](cap int) *Set[E]

NewSetWithCap 创建一个set集合, 可设置 cap容量

func OfSet

func OfSet[E comparable](keyMap map[E]struct{}) *Set[E]

func (*Set[E]) Add

func (my *Set[E]) Add(ele E)

func (*Set[E]) Contains

func (my *Set[E]) Contains(ele E) bool

func (*Set[E]) ForEach

func (my *Set[E]) ForEach(action func(t E))

ForEach 切片的循环操作

func (*Set[E]) IsEmpty

func (my *Set[E]) IsEmpty() bool

func (*Set[E]) Remove

func (my *Set[E]) Remove(ele E) bool

func (*Set[E]) Size

func (my *Set[E]) Size() int

func (*Set[E]) Stream

func (my *Set[E]) Stream() streams.Stream[E]

Stream 将Set转化为Stream流处理

func (*Set[E]) ToList

func (my *Set[E]) ToList() *List[E]

Jump to

Keyboard shortcuts

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