commons-dev mailing list archives

Site index · List index
Message view « Date » · « Thread »
Top « Date » · « Thread »
Subject [jira] Updated: (JELLY-148) Huge memory leak resulting from the use of ThreadLocal
Date Sun, 19 Sep 2004 20:31:38 GMT
The following issue has been updated:

    Updater: Hans Gilde (
       Date: Sun, 19 Sep 2004 1:31 PM
The simplest way to fix this problem is to prevent a Tag from holding a hard reference to
its body Script. Which this patch does.

But, the patch will break some stuff. It has an unfortunate side effect for Tags that want
to keep their body Script around after they execute. For instance, Swing action tags execute
their body as the action. If the Swing script is executed, then disposed of, the body script
won't be available when the action is executed.

However, the action Tag simply cannot be allowed to keep a hard reference to its body. If
it keeps the hard reference, it will be trapped in the ThreadLocal forever. Argh.

I'm trying to come up with a solution to this situation that doesn't horribly complicate things.
             Attachment changed to thread-local-memory-leak-fix-demo.txt
For a full history of the issue, see:

View the issue:

Here is an overview of the issue:
        Key: JELLY-148
    Summary: Huge memory leak resulting from the use of ThreadLocal
       Type: Bug

     Status: Unassigned
   Priority: Critical

    Project: jelly
             core / taglib.core

   Reporter: Hans Gilde

    Created: Sat, 18 Sep 2004 9:34 PM
    Updated: Sun, 19 Sep 2004 1:31 PM

There is a huge memory leak that results from the TagScript's use of ThreadLocal.

ThreadLocal is usually used from a staic variable, while TagScript uses it from an instance
variable. Although this looks legal to me, it causes a huge memory leak.

This message is automatically generated by JIRA.

If you think it was sent incorrectly contact one of the administrators:

If you want more information on JIRA, or have a bug to report see:

To unsubscribe, e-mail:
For additional commands, e-mail:

View raw message