concurrent包下的很多框架实现基本都依赖于AQS ,而AQS底层依赖LockSupport ,LockSupport依赖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);