并发编程----原子变量与非阻塞同步机制



1,近年来,在并发算法领域的大多数研究都侧重于非阻塞算法,这种算法用底层的原子机器指令(例如比较并交换指令)代替锁来确保数据在并发访问中的一致性。
2,与基于锁的方案相比,非阻塞算法在设计和实现上都要复杂得多,但它们在可伸缩性和活跃性上却拥有巨大的优势。
3,锁的劣势

  3.1,当有多个线程同时请求锁时,JVM需要借助操作系统的功能,将线程挂起并且在稍后恢复运行。当锁上存在着激烈的竞争时,调度开销与工作开销的比值会比较高
  3.2,volatile在使用时不会发生上下文切换或者线程调度操作。
  3.3,锁还有一个缺点是,当一个线程正在等待锁时,他不能做任何其他事情。
4,硬件对并发的支持

public class SimulatedCAS {//模拟CAS操作
    @GuardedBy("this") private int value;

    public synchronized int get() { return value; }

    public synchronized int compareAndSwap(int expectedValue,
                                           int newValue) {//相当于处理器的CAS原子化操作
        int oldValue = value;
        if (oldValue == expectedValue)
            value = newValue;
        return oldValue;
    }

    public synchronized boolean compareAndSet(int expectedValue,
                                              int newValue) {
        return (expectedValue
                == compareAndSwap(expectedValue, newValue));
    }
}



  4.1,堵占锁是一项悲观技术---它假设最坏的情况,并且只有在确保其他线程不会造成干扰的情况下才能执行下去。
  4.2,几乎所有的现代处理器中都包含某种形式的原子读-该-写指令,例如比较并交换或者关键加载/条件存储
  4.3,比较并交换,在大多数处理器架构中采用的方法是实现一个比较并交换(CAS)指令。CAS是一项乐观的技术,它希望能成功地执行更新操作,并且如果有另一个线程在最近一次检查后更新了该变量,那么CAS能检测到这个错误。当线程在竞争CAS失败时不会被挂起,而是告知这次竞争中失败,它不会阻塞线程,可以再次尝试或执行一些恢复操作。
  4.4,在大多数处理器上,在无竞争的锁获取和释放的“快速代码路径”上的开销,大约是CAS开销的两倍。CAS的主要缺点是,它将使调用者处理竞争问题(重试,回退,放弃),而在锁中能自动处理竞争问题(阻塞)。
  4.5,JVM对CAS的支持,在原子变量类(AtomicXxx)中使用这些底层的JVM支持的数字类型和引用类型提供一种高效的CAS操作,而在java.util.concurrent中的大多数类在实现时则直接或间接地使用了这些原子变量类。
5,原子变量类

public class CasNumberRange {
    private static class IntPair{
        // 不变性条件: lower <= upper
        final int lower;
        final int upper;
        
        public IntPair(int lower, int upper) {
            this.lower = lower;
            this.upper = upper;
        }
    }
    
    private AtomicReference<IntPair> values = new AtomicReference<>();
    
    public int getLower(){
        return values.get().lower;
    }
    
    public int getUpper(){
        return values.get().upper;
    }
    
    public void setLower(int i){
        while (true){
            IntPair oldv = values.get();
            if (i > oldv.upper){
                throw new IllegalArgumentException("lower can't > upper");
            }
            IntPair newv = new IntPair(i, oldv.upper);
            if (values.compareAndSet(oldv, newv)){
                return;
            }
        }
    }
}

通过CAS来维持包含多个变量的不变性条件



  5.1,原子变量类不需要挂起或重新调度线程
  5.2,共有12个原子变量类,可分为4组:标量类,更新器类,数组类以及符合变量类
  5.3,原子变量类的标量类扩展了Number类,但没有扩展它们的包装类,基本类型的包装类时不可修改的,而原子变量类是可修改的,原子变量类中没有重新定义hashCode或equals方法
  5.4,原子变量是一种“更好的volatile”

  5.5,与CAS的算法一样,基于原子变量的compareAndSet的调度遇到竞争时立即重试,这将在激烈的竞争环境下导致更多的竞争。在中低程度竞争下,原子变量能够提供更高的可伸缩性,而在高强度的竞争下,锁能够更有效地避免竞争。

6,非阻塞算法
  6.1,如果一个算法中,一个线程的失败或挂起不会导致其他线程也失败或挂起,那么这种算法就被称为非阻塞算法,
  6.2,如果在算法的每个步骤中都存在某个线程能够执行下去,那么这种算法也被称为无锁(Lock-Free)算法
  6.3,如果算法中仅将CAS用于协调线程之间的操作,并且能够正确的实现,那么他既是一种无阻塞算法,又是一种无锁算法
  6.4,构建非阻塞算法的技巧在于:将执行原子修改的范围缩小到单个变量上
  6.5,原子的域更新器类(AtomicReferenceFieldUpdater)提供的原子性保证比普通原子类更弱一些,因为无法保证底层的域不被直接修改
7,ABA问题,指的是某个条件V首先由A变成B,再有B变成A。可以通过“”版本号“从而避免ABA问题。
8,非阻塞算法通过底层的并发原语来维持线程的安全性,这些底层的原语通过原子变量类向外公开,这些类也用作一种“更好的volatile变量”,从而为整数和对象引用提供原子的更新操作

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
智慧校园信息化系统解决方案旨在通过先进的信息技术,实现教育的全方位创新和优质资源的普及共享。该方案依据国家和地方政策背景,如教育部《教育信息化“十三五”规划》和《教育信息化十年发展规划》,以信息技术的革命性影响为指导,推进教育信息化建设,实现教育思想和方法的创新。 技术发展为智慧校园建设提供了强有力的支撑。方案涵盖了互连互通、优质资源共享、宽带网络、移动APP、电子书包、电子教学白板、3D打印、VR虚拟教学等技术应用,以及大数据和云计算技术,提升了教学数据记录和分析水平。此外,教育资源公共服务平台、教育管理公共服务平台等平台建设,进一步提高了教学、管控的效率。 智慧校园系统由智慧教学、智慧管控和智慧办公三大部分组成,各自具有丰富的应用场景。智慧教学包括微课、公开课、精品课等教学资源的整合和共享,支持在线编辑、录播资源、教学分析等功能。智慧管控则通过平安校园、可视对讲、紧急求助、视频监控等手段,保障校园安全。智慧办公则利用远程视讯、无纸化会议、数字会议等技术,提高行政效率和会议质量。 教育录播系统作为智慧校园的重要组成部分,提供了一套满足学校和教育局需求的解决方案。它包括标准课室、微格课室、精品课室等,通过自动五机位方案、高保真音频采集、一键式录课等功能,实现了优质教学资源的录制和共享。此外,录播系统还包括互动教学、录播班班通、教育中控、校园广播等应用,促进了教育资源的均衡化发展。 智慧办公的另一重点是无纸化会议和数字会议系统的建设,它们通过高效的文件管理、会议文件保密处理、本地会议的音频传输和摄像跟踪等功能,实现了会议的高效化和集中管控。这些系统不仅提高了会议的效率和质量,还通过一键管控、无线管控等设计,简化了操作流程,使得会议更加便捷和环保。 总之,智慧校园信息化系统解决方案通过整合先进的信息技术和教学资源,不仅提升了教育质量和管理效率,还为实现教育均衡化和资源共享提供了有力支持,推动了教育现代化的进程。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值