Commit 5c389be0 authored by Daniel Maier's avatar Daniel Maier Committed by Dave Cridland

OF-565 use thread local instead of map with threads hashcode as key (this...

OF-565 use thread local instead of map with threads hashcode as key (this could lead to collissions)
parent 285b6aa5
...@@ -57,7 +57,16 @@ public abstract class ConnectionHandler extends IoHandlerAdapter { ...@@ -57,7 +57,16 @@ public abstract class ConnectionHandler extends IoHandlerAdapter {
protected static final String CONNECTION = "CONNECTION"; protected static final String CONNECTION = "CONNECTION";
protected String serverName; protected String serverName;
private static Map<Integer, XMPPPacketReader> parsers = new ConcurrentHashMap<Integer, XMPPPacketReader>(); private static final ThreadLocal<XMPPPacketReader> PARSER_CACHE = new ThreadLocal<XMPPPacketReader>()
{
@Override
protected XMPPPacketReader initialValue()
{
final XMPPPacketReader parser = new XMPPPacketReader();
parser.setXPPFactory( factory );
return parser;
}
};
/** /**
* Reuse the same factory for all the connections. * Reuse the same factory for all the connections.
*/ */
...@@ -166,13 +175,7 @@ public abstract class ConnectionHandler extends IoHandlerAdapter { ...@@ -166,13 +175,7 @@ public abstract class ConnectionHandler extends IoHandlerAdapter {
// to be a parser for each running thread. Each Filter will be executed // to be a parser for each running thread. Each Filter will be executed
// by the Executor placed as the first Filter. So we can have a parser associated // by the Executor placed as the first Filter. So we can have a parser associated
// to each Thread // to each Thread
int hashCode = Thread.currentThread().hashCode(); final XMPPPacketReader parser = PARSER_CACHE.get();
XMPPPacketReader parser = parsers.get(hashCode);
if (parser == null) {
parser = new XMPPPacketReader();
parser.setXPPFactory(factory);
parsers.put(hashCode, parser);
}
// Update counter of read btyes // Update counter of read btyes
updateReadBytesCounter(session); updateReadBytesCounter(session);
//System.out.println("RCVD: " + message); //System.out.println("RCVD: " + message);
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment