|
14 | 14 | */ |
15 | 15 | package org.apache.geode.cache.query.internal; |
16 | 16 |
|
| 17 | + |
17 | 18 | import org.apache.geode.annotations.Immutable; |
18 | 19 | import org.apache.geode.annotations.internal.MakeNotStatic; |
19 | 20 |
|
@@ -49,31 +50,46 @@ public class QueryObserverHolder { |
49 | 50 | * The current observer which will be notified of all query events. |
50 | 51 | */ |
51 | 52 | @MakeNotStatic |
52 | | - private static ThreadLocal<QueryObserver> _instance = ThreadLocal.withInitial(() -> NO_OBSERVER); |
| 53 | + private static final ThreadLocal<QueryObserver> _instance = new ThreadLocal<>(); |
| 54 | + |
| 55 | + private static volatile QueryObserver _globalInstance = NO_OBSERVER; |
53 | 56 |
|
54 | 57 | /** |
55 | 58 | * Set the given observer to be notified of query events. Returns the current observer. |
56 | 59 | */ |
57 | | - public static QueryObserver setInstance(QueryObserver observer) { |
| 60 | + public static synchronized QueryObserver setInstance(QueryObserver observer) { |
58 | 61 | Support.assertArg(observer != null, "setInstance expects a non-null argument!"); |
59 | | - QueryObserver oldObserver = _instance.get(); |
| 62 | + QueryObserver oldObserver; |
| 63 | + if (_instance.get() != null) { |
| 64 | + oldObserver = _instance.get(); |
| 65 | + } else { |
| 66 | + oldObserver = _globalInstance; |
| 67 | + } |
60 | 68 | _instance.set(observer); |
| 69 | + _globalInstance = observer; |
61 | 70 | return oldObserver; |
62 | 71 | } |
63 | 72 |
|
64 | | - public static boolean hasObserver() { |
65 | | - return _instance.get() != NO_OBSERVER; |
| 73 | + public static synchronized boolean hasObserver() { |
| 74 | + if (_instance.get() != null) { |
| 75 | + return _instance.get() != NO_OBSERVER; |
| 76 | + } |
| 77 | + return _globalInstance != NO_OBSERVER; |
66 | 78 | } |
67 | 79 |
|
68 | 80 | /** Return the current QueryObserver instance */ |
69 | 81 | public static QueryObserver getInstance() { |
70 | | - return _instance.get(); |
| 82 | + if (_instance.get() != null) { |
| 83 | + return _instance.get(); |
| 84 | + } |
| 85 | + return _globalInstance; |
71 | 86 | } |
72 | 87 |
|
73 | 88 | /** |
74 | 89 | * Only for test purposes. |
75 | 90 | */ |
76 | 91 | public static void reset() { |
77 | 92 | _instance.set(NO_OBSERVER); |
| 93 | + _globalInstance = NO_OBSERVER; |
78 | 94 | } |
79 | 95 | } |
0 commit comments