You are viewing a plain text version of this content. The canonical link for it is here.
Posted to issues@commons.apache.org by "Michele Vivoda (JIRA)" <ji...@apache.org> on 2015/08/03 17:15:05 UTC
[jira] [Created] (JXPATH-181) ValueUtils modifies a static HashMap
field without synchronization
Michele Vivoda created JXPATH-181:
-------------------------------------
Summary: ValueUtils modifies a static HashMap field without synchronization
Key: JXPATH-181
URL: https://issues.apache.org/jira/browse/JXPATH-181
Project: Commons JXPath
Issue Type: Bug
Reporter: Michele Vivoda
ValueUtils uses a HashMap to cache instances of DynamicPropertyHandler that otherwise creates from a java.lang.Class object.
https://github.com/apache/commons-jxpath/blob/JXPATH_1_3_RC4/src/java/org/apache/commons/jxpath/util/ValueUtils.java#L44
https://github.com/apache/commons-jxpath/blob/JXPATH_1_3_RC4/src/java/org/apache/commons/jxpath/util/ValueUtils.java#L549
Since the getDynamicPropertyHandler method is static and modifies the HashMap, thread safety is broken.
The easiest option would be to use Collections.SynchronizedMap(), introducing more locking.
An other option is to remove cache: Class.newInstance() is not so heavy since all internal implementations of DynamicPropertyHandler perform almost no initialization in constructor. A side effect of removing cache could be external implementations of DynamicPropertyHandler not expecting to be created multiple times, but not sure if this is the case.
I did some tests all creating an instance from a almost-no-initialization class object using Class.newInstance(): 2 with cache (HashMap and Collections.synchronizedMap()) and one without cache.
First one thread, 50000x1000 loops
junit.perf.util.AccessorHashMap :259 (12.84%) 21.99% of max
junit.perf.util.AccessorSynchmap :1178 (58.4%) 100.0% of max
junit.perf.util.AccessorNoCache :580 (28.75%) 49.24% of max
then 1000 threads 50000 loops
junit.perf.util.AccessorHashMap :128 (3.82%) 4.51% of max
junit.perf.util.AccessorSynchmap :2840 (84.95%) 100.0% of max
junit.perf.util.AccessorNoCache :375 (11.21%) 13.2% of max
>From results I see no cache is not so bad also compared to HashMap, perhaps more important is that with 1000 threads Synchmap uses much more time than with one thread (240%), while the other 2 implementations use less; test machine has more than one processor.
So I propose to remove caching from ValueUtils
If one day DynamicPropertyHandler implementations will be registered in some static way like using property files (and not with static methods like now) - then may be will be possible to cache only those registered in properties in an unmodifiable not synchronized map and just create the others
--
This message was sent by Atlassian JIRA
(v6.3.4#6332)