diff --git a/hibernate-core/src/main/java/org/hibernate/context/internal/JTASessionContext.java b/hibernate-core/src/main/java/org/hibernate/context/internal/JTASessionContext.java index 5c4397bb34..3b6bf25cea 100644 --- a/hibernate-core/src/main/java/org/hibernate/context/internal/JTASessionContext.java +++ b/hibernate-core/src/main/java/org/hibernate/context/internal/JTASessionContext.java @@ -23,8 +23,9 @@ */ package org.hibernate.context.internal; -import java.util.Hashtable; import java.util.Map; +import java.util.concurrent.ConcurrentHashMap; + import javax.transaction.Synchronization; import javax.transaction.Transaction; import javax.transaction.TransactionManager; @@ -67,7 +68,7 @@ import org.hibernate.service.jta.platform.spi.JtaPlatform; public class JTASessionContext extends AbstractCurrentSessionContext { private static final CoreMessageLogger LOG = Logger.getMessageLogger(CoreMessageLogger.class, JTASessionContext.class.getName()); - private transient Map currentSessionMap = new Hashtable(); + private transient Map currentSessionMap = new ConcurrentHashMap(); public JTASessionContext(SessionFactoryImplementor factory) { super( factory ); @@ -103,7 +104,7 @@ public class JTASessionContext extends AbstractCurrentSessionContext { final Object txnIdentifier = jtaPlatform.getTransactionIdentifier( txn ); - Session currentSession = ( Session ) currentSessionMap.get( txnIdentifier ); + Session currentSession = currentSessionMap.get( txnIdentifier ); if ( currentSession == null ) { currentSession = buildOrObtainSession();