I’m sure I am doing something stupid here - but I can’t see it :
It seems that the default select (from an unbuffered channel) has a timeout that I can’t avoid.
I have the following init() :
func init() {
moves = make(moveChannel, 0)
go updateRelativeMove(moves)
}
Then I have this update :
func updateRelativeMove(moves moveChannel) {
move_pair := newMovePair()
for {
select {
case new_move := <-moves:
if new_move.x != nil {
move_pair.x = new_move.x
}
if new_move.y != nil {
move_pair.y = new_move.y
}
fmt.Println("<-", *move_pair.x, *move_pair.y)
default:
interval(move_pair)
time.Sleep(INTERVAL)
}
}
}
Where INTERVAL is const INTERVAL = time.Duration(time.Second / 30)
and and I have checked the runtime value as well - it is reported as ‘33.333333ms’, i.e. 0.033 secs or 1/30th second.
What happens is that my interval gets called ~15 times a second and so the updates are (of course) calculated wrong - but I expect this to be ~30 times a second. Note that this is when the first case is not matched - i.e. no messages are received from the channel.
I could calculate (at runtime) the time since the last interval - but this shouldn’t be necessary - interval should be called 30 times a second - my only thought is that the unbuffered message read is itself taking the rest of the time - even though that is only about 15 calls a second?!
Note: If I change the interval to 1/60th seconds I get ~38 calls/second
Any help please - best wishes - Andy