Skip to content

Commit

Permalink
Replace synchronized method with Lock
Browse files Browse the repository at this point in the history
Should fix #1022
  • Loading branch information
harawata committed Dec 9, 2024
1 parent 0cff0ea commit ef63486
Showing 1 changed file with 10 additions and 3 deletions.
13 changes: 10 additions & 3 deletions src/main/java/org/mybatis/spring/MyBatisExceptionTranslator.java
Original file line number Diff line number Diff line change
Expand Up @@ -16,6 +16,7 @@
package org.mybatis.spring;

import java.sql.SQLException;
import java.util.concurrent.locks.ReentrantLock;
import java.util.function.Supplier;

import javax.sql.DataSource;
Expand All @@ -41,6 +42,7 @@ public class MyBatisExceptionTranslator implements PersistenceExceptionTranslato

private final Supplier<SQLExceptionTranslator> exceptionTranslatorSupplier;
private SQLExceptionTranslator exceptionTranslator;
private ReentrantLock lock = new ReentrantLock();

/**
* Creates a new {@code PersistenceExceptionTranslator} instance with {@code SQLErrorCodeSQLExceptionTranslator}.
Expand Down Expand Up @@ -104,9 +106,14 @@ public DataAccessException translateExceptionIfPossible(RuntimeException e) {
/**
* Initializes the internal translator reference.
*/
private synchronized void initExceptionTranslator() {
if (this.exceptionTranslator == null) {
this.exceptionTranslator = exceptionTranslatorSupplier.get();
private void initExceptionTranslator() {
lock.lock();
try {
if (this.exceptionTranslator == null) {
this.exceptionTranslator = exceptionTranslatorSupplier.get();
}
} finally {
lock.unlock();
}
}

Expand Down

0 comments on commit ef63486

Please sign in to comment.