JDK 9 RFR of 6375303: Review use of caching in BigDecimal

Mike Duigou mike.duigou at oracle.com
Tue Mar 4 17:21:26 UTC 2014


On Mar 4 2014, at 07:13 , Peter Levart <peter.levart at gmail.com> wrote:

> On 03/04/2014 01:14 AM, Brian Burkhalter wrote:
>> - add AtomicReferenceFieldUpdater-type constant for stringCache initialization
> 
> Hi Brian,
> 
> By using volatile read and CAS, there's still a chance that multiple concurrent threads will be invoking the layoutChars(true) concurrently, but you guarantee that only a single instance of String will ever be returned as a result of the toString() method. Is that what you were pursuing?

Yes. (I provided the AtomicReferenceFieldUpdater code). The previous implementation had a benign data race that could result in a later layoutChars result replacing an earlier result and multiple string instances being returned. The new implementation, at small cost, prevents multiple different instances from being returned.

Mike


More information about the core-libs-dev mailing list