标签:能力 val class 分配 依赖 lock div unpark public
concurrent包下的很多框架实现基本都依赖于AQS ,而AQS底层依赖LockSupport ,LockSupport依赖Unsafe提供的能力进行加锁等操作
1.park() unpark()
内部基于互斥量机制 permit初始值为0
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);
标签:能力 val class 分配 依赖 lock div unpark public
原文地址:https://www.cnblogs.com/lnas01/p/10351625.html