Commit f91cd447 authored by Rob Pike's avatar Rob Pike

save a few ns by inlining (which mostly simplifies things anyway).

a couple of cleanups.
don't keep big buffers in the free list.

R=rsc
CC=golang-dev
https://golang.org/cl/166078
parent 353ef80f
This diff is collapsed.
...@@ -136,7 +136,6 @@ type GoStringer interface { ...@@ -136,7 +136,6 @@ type GoStringer interface {
GoString() string; GoString() string;
} }
const runeSelf = utf8.RuneSelf
const allocSize = 32 const allocSize = 32
type pp struct { type pp struct {
...@@ -149,17 +148,25 @@ type pp struct { ...@@ -149,17 +148,25 @@ type pp struct {
// A leaky bucket of reusable pp structures. // A leaky bucket of reusable pp structures.
var ppFree = make(chan *pp, 100) var ppFree = make(chan *pp, 100)
// Allocate a new pp struct. Probably can grab the previous one from ppFree.
func newPrinter() *pp { func newPrinter() *pp {
p, ok := <-ppFree; p, ok := <-ppFree;
if !ok { if !ok {
p = new(pp) p = new(pp)
} }
p.buf.Reset();
p.fmt.init(&p.buf); p.fmt.init(&p.buf);
return p; return p;
} }
func (p *pp) free() { _ = ppFree <- p } // Save used pp structs in ppFree; avoids an allocation per invocation.
func (p *pp) free() {
// Don't hold on to pp structs with large buffers.
if cap(p.buf.Bytes()) > 1024 {
return
}
p.buf.Reset();
_ = ppFree <- p;
}
func (p *pp) Width() (wid int, ok bool) { return p.fmt.wid, p.fmt.widPresent } func (p *pp) Width() (wid int, ok bool) { return p.fmt.wid, p.fmt.widPresent }
...@@ -182,7 +189,7 @@ func (p *pp) Flag(b int) bool { ...@@ -182,7 +189,7 @@ func (p *pp) Flag(b int) bool {
} }
func (p *pp) add(c int) { func (p *pp) add(c int) {
if c < runeSelf { if c < utf8.RuneSelf {
p.buf.WriteByte(byte(c)) p.buf.WriteByte(byte(c))
} else { } else {
w := utf8.EncodeRune(c, &p.runeBuf); w := utf8.EncodeRune(c, &p.runeBuf);
...@@ -250,8 +257,9 @@ func Sprint(a ...) string { ...@@ -250,8 +257,9 @@ func Sprint(a ...) string {
v := reflect.NewValue(a).(*reflect.StructValue); v := reflect.NewValue(a).(*reflect.StructValue);
p := newPrinter(); p := newPrinter();
p.doprint(v, false, false); p.doprint(v, false, false);
s := p.buf.String();
p.free(); p.free();
return p.buf.String(); return s;
} }
// These routines end in 'ln', do not take a format string, // These routines end in 'ln', do not take a format string,
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment