Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/kazu/loncha
fast slice utility for golang
https://github.com/kazu/loncha
golang slice
Last synced: 3 months ago
JSON representation
fast slice utility for golang
- Host: GitHub
- URL: https://github.com/kazu/loncha
- Owner: kazu
- License: mit
- Created: 2019-03-01T05:34:28.000Z (almost 6 years ago)
- Default Branch: master
- Last Pushed: 2022-07-21T20:43:21.000Z (over 2 years ago)
- Last Synced: 2024-08-03T19:10:00.558Z (6 months ago)
- Topics: golang, slice
- Language: Go
- Homepage:
- Size: 231 KB
- Stars: 8
- Watchers: 2
- Forks: 1
- Open Issues: 1
-
Metadata Files:
- Readme: README.md
- Funding: .github/FUNDING.yml
- License: LICENSE
Awesome Lists containing this project
- awesome-go-extra - loncha - 03-01T05:34:28Z|2022-07-21T20:43:21Z| (Utilities / Fail injection)
README
# loncha
[![Build Status](https://github.com/kazu/loncha/actions/workflows/go.yml/badge.svg)](https://github.com/kazu/loncha/actions/workflows/go.yml)
[![Go Report Card](https://goreportcard.com/badge/github.com/kazu/loncha)](https://goreportcard.com/report/github.com/kazu/loncha)
[![codecov](https://codecov.io/gh/kazu/loncha/branch/master/graph/badge.svg)](https://codecov.io/gh/kazu/loncha)
[![GitHub go.mod Go version of a Go module](https://img.shields.io/github/go-mod/go-version/gomods/athens.svg)](https://github.com/kazu/loncha)
[![GitHub release](https://img.shields.io/github/v/release/kazu/loncha.svg)](https://github.com/kazu/loncha)A high-performance slice Utilities for Go.
* high-performance slice filter/finder.
* linked-list generics template using [Gennry]## Installation
### slice Utility
go get github.com/kazu/loncha
## QuickStart
### slice Utility
slice utility dosent use reflect/interface operation.
```go
import "github.com/kazu/loncha"type GameObject struct {
ID int
Name string
Pos []float
}...
var objs []GameObject
```
find object from slice
```go
loncha.Find(&objs, func(i int) bool {
return objs[i].ID == 6
}
```filter/delete object via condition function
```go
loncha.Filter(&objs, func(obj *GameObject) bool {
return obj.ID == 12
}loncha.Delete(&objs, func(i int) bool {
return objs[i].ID == 555
})
```select object with condition function
```go
// find one object with conditions.
obj, err := Select(&objs, func(i int) bool {
return slice[i].ID < 50
})
```shuffle slice
```go
err = loncha.Shuffle(objs, 2)loncha.Reverse(objs)
```got intersection from two slices
```go
var obj2 []GameObject
intersectedObj := InsertSect(obj, obj2)sort.Slice(objs, func(i int) bool {
return objs[i].ID >= objs[j].ID
})
sort.Slice(objs2, func(i int) bool {
return objs[i].ID >= objs[j].ID
})intersect2 := IntersectSorted(obj, obj2, func(s []GameObject, i int) int {
return s[i].ID
})
```subtraction from two slices
```go
subtractObj := Sub(obj, obj2)subtract2 := SubSorted(obj, obj2, func(s []GameObject, i int) int {
return s[i].ID
})```
Returns an object formed from operands via function
```go
slice1 := []int{10, 6, 4, 2}sum := Inject(slice1, func(sum *int, t int) int {
return *sum + t
})
```## generate double-linked list of linux kernel list_head type
define base struct
```
package game_objectimport (
"github.com/kazu/loncha/list_head"type Player struct {
ID int
Name string
Hp int
list_head.ListHead
}
```generate linked-list
```console
$ go get go get github.com/cheekybits/genny
$ wget -q -O - "https://github.com/kazu/loncha/master/container_list/list.go" | genny gen "ListEntry=Player" > player_list.go
$ wget -q -O - "https://github.com/kazu/loncha/master/container_list/list_test.go" | genny gen "ListEntry=Player" > player_list_test.go
```
## benchmark Result### loncha.Uniq vs hand Uniq vs go-funk.Uniq
```
loncha.Uniq-16 1000 997543 ns/op 548480 B/op 16324 allocs/op
loncha.UniqWithSort-16 1000 2237924 ns/op 256 B/op 7 allocs/op
loncha.UniqWithSort(sort)-16 1000 260283 ns/op 144 B/op 4 allocs/op
hand_Uniq-16 1000 427765 ns/op 442642 B/op 8 allocs/op
hand_Uniq_iface-16 1000 808895 ns/op 632225 B/op 6322 allocs/op
go-funk.Uniq-16 1000 1708396 ns/op 655968 B/op 10004 allocs/op
```### loncha.Filter vs go-funk.Filter
```
loncha.Filter-16 100 89142 ns/op 82119 B/op 4 allocs/op
loncha.Filter_pointer-16 100 201 ns/op 0 B/op 0 allocs/op
hand_Filter_pointer-16 100 24432 ns/op 81921 B/op 1 allocs/op
go-funk.Filter-16 100 2370492 ns/op 640135 B/op 20004 allocs/op
go-funk.Filter_pointer-16 100 1048 ns/op 64 B/op 2 allocs/op
```## References
- [Gennry]
[Gennry]: https://github.com/cheekybits/genny