diff options
author | Matthew Newhook <matthew@zeroc.com> | 2008-08-15 14:47:14 -0230 |
---|---|---|
committer | Matthew Newhook <matthew@zeroc.com> | 2008-08-15 14:47:14 -0230 |
commit | 7b735386b10c464a39d4e0298c99a33f6ae038fe (patch) | |
tree | 7f2e9ee218038b3b3883e3827b82ec70533aff8f /java/demo/Database/library/ReapThread.java | |
parent | Fix more conflicts. (diff) | |
download | ice-7b735386b10c464a39d4e0298c99a33f6ae038fe.tar.bz2 ice-7b735386b10c464a39d4e0298c99a33f6ae038fe.tar.xz ice-7b735386b10c464a39d4e0298c99a33f6ae038fe.zip |
added first cut at JDBC demo.
Diffstat (limited to 'java/demo/Database/library/ReapThread.java')
-rw-r--r-- | java/demo/Database/library/ReapThread.java | 102 |
1 files changed, 102 insertions, 0 deletions
diff --git a/java/demo/Database/library/ReapThread.java b/java/demo/Database/library/ReapThread.java new file mode 100644 index 00000000000..5bef3cd3c50 --- /dev/null +++ b/java/demo/Database/library/ReapThread.java @@ -0,0 +1,102 @@ +// ********************************************************************** +// +// Copyright (c) 2003-2008 ZeroC, Inc. All rights reserved. +// +// This copy of Ice is licensed to you under the terms described in the +// ICE_LICENSE file included in this distribution. +// +// ********************************************************************** + +import Demo.*; + +class ReapThread extends Thread +{ + static class SessionProxyPair + { + SessionProxyPair(Demo.SessionPrx p, SessionI s) + { + proxy = p; + session = s; + } + + Demo.SessionPrx proxy; + SessionI session; + } + + ReapThread(Ice.Logger logger) + { + _logger = logger; + } + + synchronized public void + run() + { + while(!_terminated) + { + try + { + wait(1000); + } + catch(InterruptedException e) + { + } + + if(!_terminated) + { + java.util.Iterator<SessionProxyPair> p = _sessions.iterator(); + while(p.hasNext()) + { + SessionProxyPair s = p.next(); + try + { + // + // Session destruction may take time in a + // real-world example. Therefore the current time + // is computed for each iteration. + // + if((System.currentTimeMillis() - s.session.timestamp()) > _timeout) + { + _logger.trace("ReapThread", "The session " + s.proxy.ice_getIdentity() + " has timed out."); + s.proxy.destroy(); + p.remove(); + } + } + catch(Ice.ObjectNotExistException e) + { + p.remove(); + } + } + } + } + } + + synchronized public void + terminate() + { + _terminated = true; + notify(); + + // Destroy each of the sessions, releasing any resources they + // may hold. This calls directly on the session, not via the + // proxy since terminate() is called after the communicator is + // shutdown, which means calls on collocated objects is not + // permitted. + java.util.Iterator<SessionProxyPair> p = _sessions.iterator(); + while(p.hasNext()) + { + p.next().session.shutdown(); + } + _sessions.clear(); + } + + synchronized public void + add(SessionPrx proxy, SessionI session) + { + _sessions.add(new SessionProxyPair(proxy, session)); + } + + private final long _timeout = 10 * 1000; // 10 seconds. + private Ice.Logger _logger; + private boolean _terminated = false; + private java.util.List<SessionProxyPair> _sessions = new java.util.LinkedList<SessionProxyPair>(); +} |