ok, done for DefaultHTMLCleaner and DefaultObservationManager.
Please all be aware of this and verify the component is thread safe
when you work on one.
Thanks to Zdenek for suggesting the usage of ConcurrentHashMap.
Thanks
-Vincent
On Oct 1, 2008, at 11:55 AM, Vincent Massol wrote:
On Oct 1, 2008, at 11:32 AM, Zdenek Machac wrote:
Hi,
Vincent Massol napsal(a):
Hi,
I think we might need to review our singleton components (i.e. all
of
them ;)) for sync. issues.
For example take DefaultObservationManager:
private Map<String, List<RegisteredListener>> listeners = new
HashMap<String, List<RegisteredListener>>();
It has for ex a addListener() method.
Imagine several threads all calling addListener().
Since HashMap is not synchronized this can cause problems.
Thus shared objects should all be synchronized or they should only
be
filled once (as in an initialize method for ex).
I prefer more general term "thread safe" then restrictive
"synchronized". Some structs are
thread safe without synchronization/locking (partly
ConcurrentHashMap from JSE 5.0).
yes you're right that's what I meant: "thread safety".
Thanks
-Vincent
>
>> WDYT? Do you agree there's a potential bug in the case above?
>>
>> Thanks
>> -Vincent