Rietveld Code Review Tool
Help | Bug tracker | Discussion group | Source code | Sign in
(24)

Issue 6821094: code review 6821094: reflect: fix FieldByNameFunc (Closed)

Can't Edit
Can't Publish+Mail
Start Review
Created:
12 years, 5 months ago by gri
Modified:
12 years, 4 months ago
Reviewers:
CC:
rsc, golang-dev
Visibility:
Public.

Description

reflect: fix FieldByNameFunc The existing algorithm did not properly propagate the type count from one level to the next, and as a consequence it missed collisions. Properly propagate multiplicity (count) information to the next level. benchmark old ns/op new ns/op delta BenchmarkFieldByName1 182 180 -1.10% BenchmarkFieldByName2 6273 6183 -1.43% BenchmarkFieldByName3 49267 46784 -5.04% Fixes issue 4355.

Patch Set 1 #

Patch Set 2 : diff -r b661b713984f https://code.google.com/p/go #

Patch Set 3 : diff -r b661b713984f https://code.google.com/p/go #

Patch Set 4 : diff -r b661b713984f https://code.google.com/p/go #

Patch Set 5 : diff -r b661b713984f https://code.google.com/p/go #

Patch Set 6 : diff -r b661b713984f https://code.google.com/p/go #

Patch Set 7 : diff -r 7fac8ec2f901 https://code.google.com/p/go #

Patch Set 8 : diff -r 7fac8ec2f901 https://code.google.com/p/go #

Patch Set 9 : diff -r 7fac8ec2f901 https://code.google.com/p/go #

Patch Set 10 : diff -r 2e2a1d8184e6 https://code.google.com/p/go #

Patch Set 11 : diff -r 106824fa4abe https://code.google.com/p/go #

Patch Set 12 : diff -r 106824fa4abe https://code.google.com/p/go #

Patch Set 13 : diff -r 106824fa4abe https://code.google.com/p/go #

Unified diffs Side-by-side diffs Delta from patch set Stats (+20 lines, -2 lines) Patch
M src/pkg/reflect/all_test.go View 1 2 chunks +15 lines, -0 lines 0 comments Download
M src/pkg/reflect/type.go View 1 2 3 4 5 6 7 8 9 10 1 chunk +5 lines, -2 lines 0 comments Download

Messages

Total messages: 7
gri
Hello golang-dev@googlegroups.com, I'd like you to review this change to https://code.google.com/p/go
12 years, 5 months ago (2012-11-07 19:41:16 UTC) #1
gri
hold your horses - I think there's a faster way - gri On Wed, Nov ...
12 years, 5 months ago (2012-11-07 20:31:40 UTC) #2
gri
Hello rsc@golang.org (cc: golang-dev@googlegroups.com), Please take another look.
12 years, 5 months ago (2012-11-07 23:24:18 UTC) #3
rsc
The test looks good. I don't think FieldByName needs to be changed quite so much, ...
12 years, 4 months ago (2012-11-12 20:31:43 UTC) #4
gri
Hello rsc@golang.org (cc: golang-dev@googlegroups.com), Please take another look.
12 years, 4 months ago (2012-11-13 18:41:32 UTC) #5
rsc
LGTM
12 years, 4 months ago (2012-11-13 18:44:48 UTC) #6
gri
12 years, 4 months ago (2012-11-13 18:45:35 UTC) #7
*** Submitted as http://code.google.com/p/go/source/detail?r=40ba4d4e4672 ***

reflect: fix FieldByNameFunc

The existing algorithm did not properly propagate the type
count from one level to the next, and as a consequence it
missed collisions.

Properly propagate multiplicity (count) information to the
next level.

benchmark                old ns/op    new ns/op    delta
BenchmarkFieldByName1          182          180   -1.10%
BenchmarkFieldByName2         6273         6183   -1.43%
BenchmarkFieldByName3        49267        46784   -5.04%

Fixes issue 4355.

R=rsc
CC=golang-dev
http://codereview.appspot.com/6821094
Sign in to reply to this message.

Powered by Google App Engine
RSS Feeds Recent Issues | This issue
This is Rietveld f62528b