summaryrefslogtreecommitdiff
path: root/java/src/IceSSL/SslTransceiver.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/IceSSL/SslTransceiver.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/IceSSL/SslTransceiver.java')
-rw-r--r--java/src/IceSSL/SslTransceiver.java29
1 files changed, 17 insertions, 12 deletions
diff --git a/java/src/IceSSL/SslTransceiver.java b/java/src/IceSSL/SslTransceiver.java
index 080ceb5b1e4..2ab87607dbd 100644
--- a/java/src/IceSSL/SslTransceiver.java
+++ b/java/src/IceSSL/SslTransceiver.java
@@ -26,18 +26,23 @@ final class SslTransceiver implements IceInternal.Transceiver
_logger.trace(_instance.networkTraceCategory(), s);
}
- assert(_fd != null);
- try
- {
- _fd.close();
- _fd = null;
- }
- catch(java.io.IOException ex)
+ synchronized(this)
{
- _fd = null;
- Ice.SocketException se = new Ice.SocketException();
- se.initCause(ex);
- throw se;
+ assert(_fd != null);
+ try
+ {
+ _fd.close();
+ }
+ catch(java.io.IOException ex)
+ {
+ Ice.SocketException se = new Ice.SocketException();
+ se.initCause(ex);
+ throw se;
+ }
+ finally
+ {
+ _fd = null;
+ }
}
}
@@ -331,7 +336,7 @@ final class SslTransceiver implements IceInternal.Transceiver
_shutdown = false;
}
- protected void
+ protected synchronized void
finalize()
throws Throwable
{