42、软件事务内存(Software Transactional Memory)详细解析

软件事务内存(STM)详细解析

软件事务内存(Software Transactional Memory)详细解析

1. 事务与事务线程

事务的状态被封装在一个线程本地的 Transaction 对象中,该对象可以处于三种状态之一: ACTIVE ABORTED COMMITTED 。当创建一个事务时,其默认状态为 ACTIVE 。为了方便处理未在事务中执行的线程,定义了一个常量 Transaction.COMMITTED 事务对象。

以下是 Transaction 类的代码:

public class Transaction {
    public enum Status {ABORTED, ACTIVE, COMMITTED};
    public static Transaction COMMITTED = new Transaction(Status.COMMITTED);
    private final AtomicReference<Status> status;
    static ThreadLocal<Transaction> local = new ThreadLocal<Transaction>() {
        protected Transaction initialValue() {
            return new Transaction(Stat
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值