new StringBuilder(char)
Louis Wasserman
lowasser at google.com
Sat Aug 16 19:17:22 UTC 2014
There are indications this bug has actually occurred in released JDK code
before (!!):
http://grepcode.com/file/repository.grepcode.com/java/root/jdk/openjdk/7-b147/java/util/Formatter.java#2882
To give credit where credit is due, I reported the potential for this issue
to Eddie after seeing it on StackOverflow at
http://stackoverflow.com/q/25167015.
On Aug 16, 2014 5:39 AM, "Andrew Thompson" <lordpixel at me.com> wrote:
> I've encountered bugs in production code due to this surprise.
>
> A good thing to fix.
>
> > On Aug 16, 2014, at 1:38 AM, Jeremy Manson <jeremymanson at google.com>
> wrote:
> >
> > No love from core-libs-dev? It's backwards-incompatible, but in a way
> that
> > would unbreak existing broken code. Might be a worthwhile cleanup.
> >
> > Jeremy
> >
> >
> >> On Fri, Aug 8, 2014 at 1:53 PM, Eddie Aftandilian <eaftan at google.com>
> wrote:
> >>
> >> Hi all,
> >>
> >> We recently realized that calling new StringBuilder(char) does not do
> what
> >> you would think it does. Since there is no char constructor defined,
> the
> >> char is widened to an int and the StringBuffer is presized to the
> >> character's encoded value. Thus code like this prints an empty string
> >> rather than the expected "a":
> >> System.out.println(new StringBuilder('a'));
> >>
> >> Would it be possible to add a char constructor to StringBuilder to
> prevent
> >> this problem? I understand this would change the behavior of any code
> that
> >> is currently doing this, but it's hard to imagine anyone doing this
> >> intentionally. Of the ~20 instances we found in Google's codebase, all
> >> were bugs. What is your policy on making changes like this where (a) it
> >> will cause a change in behavior, but (b) the currently behavior is
> clearly
> >> wrong?
> >>
> >> If you're willing to take the change, I'd be happy to send a patch.
> >>
> >> Thanks,
> >> Eddie
> >>
>
More information about the core-libs-dev
mailing list