2020-08-14 22:18:42 +03:00
|
|
|
import sync
|
|
|
|
|
|
|
|
const (
|
|
|
|
num_iterations = 10000
|
|
|
|
)
|
|
|
|
|
|
|
|
struct St {
|
|
|
|
mut:
|
2020-08-17 00:01:49 +03:00
|
|
|
dummy i64
|
|
|
|
dummy2 u32
|
|
|
|
dummy3 i64
|
|
|
|
n int
|
|
|
|
dummy4 int
|
2020-08-14 22:18:42 +03:00
|
|
|
}
|
|
|
|
|
|
|
|
// this function gets an array of channels for `St` references
|
|
|
|
fn do_rec_calc_send(chs []chan mut St) {
|
2020-08-17 00:01:49 +03:00
|
|
|
mut s := &St(0)
|
2020-08-14 22:18:42 +03:00
|
|
|
for {
|
|
|
|
if !(&sync.Channel(chs[0])).pop(&s) {
|
|
|
|
break
|
|
|
|
}
|
|
|
|
s.n++
|
|
|
|
(&sync.Channel(chs[1])).push(&s)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
fn test_channel_array_mut() {
|
|
|
|
mut chs := [chan mut St{cap: 1}, chan mut St{}]
|
|
|
|
go do_rec_calc_send(chs)
|
2020-08-17 00:01:49 +03:00
|
|
|
mut t := &St{
|
2020-08-14 22:18:42 +03:00
|
|
|
n: 100
|
|
|
|
}
|
|
|
|
for _ in 0 .. num_iterations {
|
|
|
|
(&sync.Channel(chs[0])).push(&t)
|
|
|
|
(&sync.Channel(chs[1])).pop(&t)
|
|
|
|
}
|
|
|
|
(&sync.Channel(chs[0])).close()
|
|
|
|
assert t.n == 100 + num_iterations
|
|
|
|
}
|