mirror of
https://github.com/duke-git/lancet.git
synced 2026-02-04 12:52:28 +08:00
74 lines
1.6 KiB
Go
74 lines
1.6 KiB
Go
// Copyright 2021 dudaodong@gmail.com. All rights reserved.
|
|
// Use of this source code is governed by MIT license
|
|
|
|
// Package concurrency contain some functions to support concurrent programming. eg, goroutine, channel, async.
|
|
package concurrency
|
|
|
|
// Channel is a logic object which implemented by go chan
|
|
// all methods of channel are in the book tiled《Concurrency in Go》
|
|
type Channel struct {
|
|
}
|
|
|
|
// NewChannel return a Channel instance
|
|
func NewChannel() *Channel {
|
|
return &Channel{}
|
|
}
|
|
|
|
// Generate a data of type any chan, put param `values` into the chan
|
|
func (c *Channel) Generate(done <-chan any, values ...any) <-chan any {
|
|
dataStream := make(chan any)
|
|
|
|
go func() {
|
|
defer close(dataStream)
|
|
|
|
for _, v := range values {
|
|
select {
|
|
case <-done:
|
|
return
|
|
case dataStream <- v:
|
|
}
|
|
}
|
|
}()
|
|
|
|
return dataStream
|
|
}
|
|
|
|
// Repeat return a data of type any chan, put param `values` into the chan repeatly,
|
|
// until close the `done` chan
|
|
func (c *Channel) Repeat(done <-chan any, values ...any) <-chan any {
|
|
dataStream := make(chan any)
|
|
|
|
go func() {
|
|
defer close(dataStream)
|
|
for {
|
|
for _, v := range values {
|
|
select {
|
|
case <-done:
|
|
return
|
|
case dataStream <- v:
|
|
}
|
|
}
|
|
}
|
|
}()
|
|
return dataStream
|
|
}
|
|
|
|
// Take return a chan whose values are tahken from another chan
|
|
func (c *Channel) Take(done <-chan any, valueStream <-chan any, number int) <-chan any {
|
|
takeStream := make(chan any)
|
|
|
|
go func() {
|
|
defer close(takeStream)
|
|
|
|
for i := 0; i < number; i++ {
|
|
select {
|
|
case <-done:
|
|
return
|
|
case takeStream <- <-valueStream:
|
|
}
|
|
}
|
|
}()
|
|
|
|
return takeStream
|
|
}
|