diff options
author | Michi Henning <michi@zeroc.com> | 2005-04-26 04:56:19 +0000 |
---|---|---|
committer | Michi Henning <michi@zeroc.com> | 2005-04-26 04:56:19 +0000 |
commit | 1f9bc3be8ae7d6ded9bae8fd902fef6bff90f651 (patch) | |
tree | 8e4dd38711a13cae633aaed0d779b5e25f0bf593 /java/src/Ice/_ObjectDelM.java | |
parent | fix for bug 248 (diff) | |
download | ice-1f9bc3be8ae7d6ded9bae8fd902fef6bff90f651.tar.bz2 ice-1f9bc3be8ae7d6ded9bae8fd902fef6bff90f651.tar.xz ice-1f9bc3be8ae7d6ded9bae8fd902fef6bff90f651.zip |
Made finalizers thread-safe.
Diffstat (limited to 'java/src/Ice/_ObjectDelM.java')
-rw-r--r-- | java/src/Ice/_ObjectDelM.java | 17 |
1 files changed, 10 insertions, 7 deletions
diff --git a/java/src/Ice/_ObjectDelM.java b/java/src/Ice/_ObjectDelM.java index 26c44951351..718183e7c79 100644 --- a/java/src/Ice/_ObjectDelM.java +++ b/java/src/Ice/_ObjectDelM.java @@ -237,13 +237,16 @@ public class _ObjectDelM implements _ObjectDel finalize() throws Throwable { - while(__outgoingCache != null) - { - IceInternal.Outgoing next = __outgoingCache.next; - __outgoingCache.destroy(); - __outgoingCache.next = null; - __outgoingCache = next; - } + synchronized(__outgoingMutex) + { + while(__outgoingCache != null) + { + IceInternal.Outgoing next = __outgoingCache.next; + __outgoingCache.destroy(); + __outgoingCache.next = null; + __outgoingCache = next; + } + } } private IceInternal.Outgoing __outgoingCache; |