Reduce heap allocations in thread.go and input.go (#1085)

I've been doing some profiling of a very simple ebiten project, and noticed that thread.go was doing a bunch of unnecessary allocations to accomplish its work. This change seeks to reduce GC work.

Input.go was also doing some unnecessary allocations.

The thread.go change reduces the total number of allocations per frame from 1342 to 852 (~36% reduction). The input.go change reduces it further to 752 (~44% total reduction). Perf tests were done on windows.
This commit is contained in:
corfe83 2020-02-20 16:59:45 -08:00 committed by GitHub
parent 5b7151595b
commit a18cddb39f
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
2 changed files with 11 additions and 15 deletions

View File

@ -52,13 +52,13 @@ func IsKeyPressed(key Key) bool {
var keys []driver.Key var keys []driver.Key
switch key { switch key {
case KeyAlt: case KeyAlt:
keys = append(keys, driver.KeyLeftAlt, driver.KeyRightAlt) keys = []driver.Key{driver.KeyLeftAlt, driver.KeyRightAlt}
case KeyControl: case KeyControl:
keys = append(keys, driver.KeyLeftControl, driver.KeyRightControl) keys = []driver.Key{driver.KeyLeftControl, driver.KeyRightControl}
case KeyShift: case KeyShift:
keys = append(keys, driver.KeyLeftShift, driver.KeyRightShift) keys = []driver.Key{driver.KeyLeftShift, driver.KeyRightShift}
default: default:
keys = append(keys, driver.Key(key)) keys = []driver.Key{driver.Key(key)}
} }
for _, k := range keys { for _, k := range keys {
if uiDriver().Input().IsKeyPressed(k) { if uiDriver().Input().IsKeyPressed(k) {

View File

@ -20,7 +20,8 @@ import (
// Thread represents an OS thread. // Thread represents an OS thread.
type Thread struct { type Thread struct {
funcs chan func() funcs chan func() error
results chan error
} }
// New creates a new thread. // New creates a new thread.
@ -28,7 +29,8 @@ type Thread struct {
// It is assumed that the OS thread is fixed by runtime.LockOSThread when New is called. // It is assumed that the OS thread is fixed by runtime.LockOSThread when New is called.
func New() *Thread { func New() *Thread {
return &Thread{ return &Thread{
funcs: make(chan func()), funcs: make(chan func() error),
results: make(chan error),
} }
} }
@ -40,7 +42,7 @@ loop:
for { for {
select { select {
case f := <-t.funcs: case f := <-t.funcs:
f() t.results <- f()
case <-context.Done(): case <-context.Done():
break loop break loop
} }
@ -51,12 +53,6 @@ loop:
// //
// Do not call this from the same thread. This would block forever. // Do not call this from the same thread. This would block forever.
func (t *Thread) Call(f func() error) error { func (t *Thread) Call(f func() error) error {
ch := make(chan struct{}) t.funcs <- f
var err error return <-t.results
t.funcs <- func() {
err = f()
close(ch)
}
<-ch
return err
} }