Executors.newCachedThreadPool 让他支持事务

Executors.newCachedThreadPool 是 Java 中创建线程池的一种方式,它创建了一个可以缓存并重用多个线程的线程池,线程池中的线程数量可以根据需要自动增长,但是这种线程池并不提供内置的事务支持。事务通常与数据库操作相关,而线程池本身不涉及数据库操作。

如果你需要在使用线程池的同时支持事务,你需要自己在业务逻辑中实现事务管理。这通常涉及到为每个任务维护一个事务上下文,并确保在同一线程中的所有任务都在同一个事务中执行。

以下是一个简单的例子,使用 ThreadLocal 来在单个线程中维持事务状态,并且在执行任务前开启事务,执行完毕后提交或回滚事务:

复制代码
import java.util.concurrent.ExecutorService;
import java.util.concurrent.Executors;
import java.util.concurrent.ThreadLocalRandom;
 
public class TransactionalExecutor {
 
    private static final ThreadLocal<Boolean> transactionActive = new ThreadLocal<>();
 
    private static final ExecutorService threadPool = Executors.newCachedThreadPool();
 
    public static void main(String[] args) {
        startTransaction();
        try {
            threadPool.submit(TransactionalExecutor::doDatabaseWork);
            threadPool.submit(TransactionalExecutor::doAnotherDatabaseWork);
        } finally {
            commitOrRollbackTransaction();
        }
        shutdownExecutor();
    }
 
    private static void startTransaction() {
        transactionActive.set(true);
        // 开启事务的逻辑
    }
 
    private static void commitOrRollbackTransaction() {
        if (transactionActive.get() != null) {
            try {
                // 根据需要执行提交或回滚
                // 提交事务的逻辑
            } finally {
                transactionActive.remove();
            }
        }
    }
 
    private static void doDatabaseWork() {
        if (transactionActive.get() != null) {
            // 数据库操作
        } else {
            throw new IllegalStateException("No active transaction");
        }
    }
 
    private static void doAnotherDatabaseWork() {
        if (transactionActive.get() != null) {
            // 另一个数据库操作
        } else {
            throw new IllegalStateException("No active transaction");
        }
    }
 
    private static void shutdownExecutor() {
        threadPool.shutdown();
    }
}
复制代码

 

在这个例子中,startTransaction 方法用于开启一个新的事务,commitOrRollbackTransaction 用于提交或回滚事务,如果在执行任务时没有检测到活动的事务,它们将抛出异常。doDatabaseWork 和 doAnotherDatabaseWork 方法在有活动事务的线程中执行数据库操作。

请注意,这个例子是为了说明概念,并不是实际可用于生产环境的代码。实际的事务管理和数据库操作会更加复杂,可能需要使用特定的数据库接口或框架来处理。

posted @   猪脚踏浪  阅读(6)  评论(0编辑  收藏  举报
编辑推荐:
· AI与.NET技术实操系列:基于图像分类模型对图像进行分类
· go语言实现终端里的倒计时
· 如何编写易于单元测试的代码
· 10年+ .NET Coder 心语,封装的思维:从隐藏、稳定开始理解其本质意义
· .NET Core 中如何实现缓存的预热?
阅读排行:
· 25岁的心里话
· 闲置电脑爆改个人服务器(超详细) #公网映射 #Vmware虚拟网络编辑器
· 零经验选手,Compose 一天开发一款小游戏!
· 因为Apifox不支持离线,我果断选择了Apipost!
· 通过 API 将Deepseek响应流式内容输出到前端
点击右上角即可分享
微信分享提示