I think the escape analysis is at fault here. The two index functions should
have the same characteristics. Both opts.isDigit and the explicit closure
capture the pointer to opts, and I don't see why the compiler shouldn't
be able to detect that the former doesn't escape just as it does the latter.

Please raise an issue at golang.org/issue.

On 4 September 2018 at 19:51, Paul D <pauld...@gmail.com> wrote:
> I'm trying to reduce allocations (and improve performance) in some Go code.
> There's a recurring pattern in the code where a struct is passed to a
> function, and the function passes one of the struct's methods to
> strings.IndexFunc. For some reason, this causes the entire struct to escape
> to the heap. If I wrap the method call in an anonymous function, the struct
> does not escape and the benchmarks run about 30% faster.
>
> Here is a minimal example. In the actual code, the struct has more
> fields/methods and the function in question actually does something. But
> this sample code illustrates the problem. Why does the opts argument escape
> to the heap in index1 but not in the functionally equivalent index2? And is
> there a robust way to ensure that it stays on the stack?
>
>
> type options struct {
>     zero rune
> }
>
> func (opts *options) isDigit(r rune) bool {
>     r -= opts.zero
>     return r >= 0 && r <= 9
> }
>
> // opts escapes to heap
> func index1(s string, opts options) int {
>     return strings.IndexFunc(s, opts.isDigit)
> }
>
> // opts does not escape to heap
> func index2(s string, opts options) int {
>     return strings.IndexFunc(s, func(r rune) bool {
>         return opts.isDigit(r)
>     })
> }
>
>
> FYI I'm running Go 1.10.3 on Linux. Thanks...

This seems like
>
>
> --
> You received this message because you are subscribed to the Google Groups
> "golang-nuts" group.
> To unsubscribe from this group and stop receiving emails from it, send an
> email to golang-nuts+unsubscr...@googlegroups.com.
> For more options, visit https://groups.google.com/d/optout.

-- 
You received this message because you are subscribed to the Google Groups 
"golang-nuts" group.
To unsubscribe from this group and stop receiving emails from it, send an email 
to golang-nuts+unsubscr...@googlegroups.com.
For more options, visit https://groups.google.com/d/optout.

Reply via email to