summaryrefslogtreecommitdiff
path: root/java/src/Ice/_ObjectDelM.java
diff options
context:
space:
mode:
authorMichi Henning <michi@zeroc.com>2005-04-26 04:56:19 +0000
committerMichi Henning <michi@zeroc.com>2005-04-26 04:56:19 +0000
commit1f9bc3be8ae7d6ded9bae8fd902fef6bff90f651 (patch)
tree8e4dd38711a13cae633aaed0d779b5e25f0bf593 /java/src/Ice/_ObjectDelM.java
parentfix for bug 248 (diff)
downloadice-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.java17
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;