|
| 1 | +package iters |
| 2 | + |
| 3 | +import "github.com/devlights/gomy/output" |
| 4 | + |
| 5 | +// Go123RangeOverFunc1 は、Go 1.23 で正式導入となった Range-Over-Func のサンプルです。 |
| 6 | +// |
| 7 | +// Range-Over-Func は、独自のイテレータを作成出来るようになる機能です。 |
| 8 | +// 以下の関数パターンがサポートされています。 |
| 9 | +// |
| 10 | +// - func(func() bool) : ループ変数に値を渡さないタイプ |
| 11 | +// - func(func(k) bool) : 1つのループ変数に値を渡すタイプ |
| 12 | +// - func(func(k, v) bool) : 2つのループ変数に値を渡すタイプ |
| 13 | +// |
| 14 | +// 本サンプルは、func(func() bool) (ループ変数に値を渡さないタイプ) についてのサンプルです。 |
| 15 | +// |
| 16 | +// # REFERENCES |
| 17 | +// - https://tip.golang.org/doc/go1.23 |
| 18 | +// - https://tip.golang.org/blog/range-functions |
| 19 | +// - https://tip.golang.org/ref/spec#For_range |
| 20 | +// - https://pkg.go.dev/iter@go1.23.3 |
| 21 | +// - https://zenn.dev/koya_iwamura/articles/7e7482c7222e37 |
| 22 | +// - https://tech.every.tv/entry/2023/12/09/1 |
| 23 | +// - https://future-architect.github.io/articles/20240129a/ |
| 24 | +func Go123RangeOverFunc1() error { |
| 25 | + var ( |
| 26 | + // 2回分のイテレータ。ループ変数に値を渡さないタイプ。 |
| 27 | + twoTimes = func(yield func() bool) { |
| 28 | + if !yield() { |
| 29 | + return |
| 30 | + } |
| 31 | + |
| 32 | + if !yield() { |
| 33 | + return |
| 34 | + } |
| 35 | + } |
| 36 | + // クロージャを使って、指定された回数ループするイテレータを返す。 |
| 37 | + nTimes = func(times int) func(func() bool) { |
| 38 | + return func(yield func() bool) { |
| 39 | + for range times { |
| 40 | + if !yield() { |
| 41 | + return |
| 42 | + } |
| 43 | + } |
| 44 | + } |
| 45 | + } |
| 46 | + ) |
| 47 | + |
| 48 | + // func() bool のイテレータなので、ループ毎に受け取るものが無い。 |
| 49 | + // (range over twoTimes (variable of type func(yield func() bool)) permits no iteration variables) |
| 50 | + for range twoTimes { |
| 51 | + output.Stdoutl("[twoTimes ]", "call") |
| 52 | + } |
| 53 | + |
| 54 | + for range nTimes(5) { |
| 55 | + output.Stdoutl("[nTimes(5)]", "call") |
| 56 | + } |
| 57 | + |
| 58 | + return nil |
| 59 | +} |
0 commit comments