-
Bug
-
Resolution: Fixed
-
P3
-
5.0, 6
-
b51
-
generic, x86
-
generic, linux
Issue | Fix Version | Assignee | Priority | Status | Resolution | Resolved In Build |
---|---|---|---|---|---|---|
JDK-2143708 | 5.0u12 | Martin Buchholz | P3 | Closed | Won't Fix |
Classes built using AbstractQueuedSynchronizer and/or SynchronousQueue
can retain garbage nodes when consumers repeatedly time out and there
are never any producers/signals.
Test code: get from jsr166 CVS:
src/test/jtreg/util/concurrent/BlockingQueue/PollMemoryLeak.java
(I don't know test harness syntax to ensure that it runs with
little enough memory to trip error in finite time. You probably
need to adjust this.)
Fix: Check for lack of signals on cancellation and clear queues.
See changes to AbstractQueuedSynchronizer and SynchronousQueue
(the new AbstractQueuedLongSynchronizer also conforms.)
###@###.### 2005-03-04 04:15:39 GMT
- backported by
-
JDK-2143708 Timeouts can cause garbage retention in lock classes
-
- Closed
-
- duplicates
-
JDK-6457123 timeouts cause garbage retention in java.util.concurrent lock classes
-
- Closed
-
-
JDK-6457125 ArrayBlockingQueue.poll(long, TimeUnit) memory leak
-
- Closed
-
- relates to
-
JDK-6460501 Synchronizer timed acquire still leaks memory
-
- Closed
-
-
JDK-6500694 Need to backport fix for 6236036 to Java 5 from Java 6
-
- Closed
-
-
JDK-6237968 Add AbstractQueuedLongSynchronizer, providing support for 64 bits of synchronization state
-
- Resolved
-
-
JDK-6491621 Documentation for timeouts cause garbage retention in java.util.concurrent lock
-
- Closed
-