zoukankan      html  css  js  c++  java
  • Unsafe.class

    concurrent包下的很多框架实现基本都依赖于AQS ,而AQS底层依赖LockSupportLockSupport依赖Unsafe提供的能力进行加锁等操作

    1.park() unpark()

    内部基于互斥量机制 permit初始值为0 *native方法

    park():如果permit等于0 阻塞;如果permit等于1 返回继续执行 并将permit设置为0

    unpark():唤醒线程,将permit + 1,最大值为1

    使用方法:

    unsafe.park(curThread);

    优点:不需要处于同步块内,同样可以达到wait的效果

    2.cas底层实现

    public final native boolean compareAndSwapInt(Object var1, long var2, int var4, int var5);
    

      

    多个线程并发访问只有一个线程可以成功

    3.创建特大数组

    java中数组的最大长度为Integer.MAX_VALUE,,通过Unsafe可以突破限制,直接进行内存分配

    long address = unsafe.allocateMemory(size);
    
    unsafe.putByte(address, (byte)i);  
    

      

  • 相关阅读:
    b站尚硅谷MySQL笔记(婷姐初级,周阳高级)
    word--公式添加编号
    excel--长数字显示问题
    R语言--蒙特卡洛计算定积分
    数学
    数学
    Computer Science
    Computer Science
    Computer Science
    元学习
  • 原文地址:https://www.cnblogs.com/lnas01/p/10351625.html
Copyright © 2011-2022 走看看