在run方法里沒法用@Transactional來做事務,run方法上又不能加exception,怎么能控制事務保證異常就回滾呢?
4 回答

千巷貓影
通過
TA貢獻1829條經驗 獲得超7個贊
ExecutorService executorService = Executors.newSingleThreadExecutor();
Future<Object> future = executorService.submit(new Callable<Object>() {
@Override
public Object call() throws Exception {
// return results
return null;
}
});
// get results
future.get();
通過concurrent
并發(fā)編程中的api
可以拿到線程的返回值。
final Lock lock = new ReentrantLock();
final Condition condition = lock.newCondition();
final AtomicReference<Object> results = new AtomicReference<>();
Thread t = new Thread() {
@Override
public void run() {
try {
Thread.sleep(500);
} catch (InterruptedException e) {
e.printStackTrace();
}
lock.lock();
// set results
results.set("success");
condition.signalAll();
lock.unlock();
}
};
t.start();
lock.lock();
condition.await();
// get results
System.out.println(results.get());
lock.unlock();
普通線程也可以使用上述方式模擬線程的返回值,來決定事務的commit/rollback
。
添加回答
舉報
0/150
提交
取消