Skip to content

Commit

Permalink
JoinPointImpl: Remove thread-locals after usage, where possible
Browse files Browse the repository at this point in the history
Avoid potential ThreadLocalMap.Entry accumulation. Entry is a
WeakReference. When JoinPointImpl objects are collected by GC, Entry
instances are still be referenced by ThreadLocalMap, which leads to
memory pressure and potentially more full GCs. So, we proactively remove
ThreadLocal<Integer> arcIndex instances when arcIndex has been
decremented back to -1 per thread. This is not perfect, because not each
thread can be expected to proceed, but it should ameliorate the
situation to some degree.

Fixes eclipse-aspectj#302.

Co-authored-by: Alexander Kriegisch <[email protected]>
Signed-off-by: KimmingLau <[email protected]>
Signed-off-by: Alexander Kriegisch <[email protected]>
  • Loading branch information
KimmingLau and kriegaex committed Apr 10, 2024
1 parent 856db5d commit 70a4547
Showing 1 changed file with 5 additions and 1 deletion.
Original file line number Diff line number Diff line change
Expand Up @@ -154,7 +154,11 @@ public final String toLongString() {
arcs = new ArrayList<>();
}
if (arc == null) {
arcIndex.set(arcIndex.get() - 1);
int newIndex = arcIndex.get() - 1;
if (newIndex > -1)
arcIndex.set(newIndex);
else
arcIndex.remove();
}
else {
this.arcs.add(arc);
Expand Down

0 comments on commit 70a4547

Please sign in to comment.