程序如何和操作系统交互
- xxx.java文件通过编译器成为xxx.class
- xxx.class字节码指令通过jvm虚拟机执行
- 有的字节码指令需要通过调用系统函数完成,在Hostpot源码里面C++函数里面定义的。
- Hostpot里面的函数通过Glibc库操作系统提供的接口,操作系统。
- 操作系统通过驱动程序,驱动硬件工作。
JUC用做干啥
用于解决多线程之间同步问题,给java开发者提供便利的原子类、数据结构、锁、线程池等。
JUC包含那些部分
原子类
锁
工具类
线程同步数据结构 线程池
JUC保证线程安全-CAS到操作系统解释
现代操作系统都是多线程的,内存中的一个值会被缓存到不同的CPU上,如果同一时间修改目前的值,就会造成数据不一致的问题。
JUC包里面的类使用了CAS方法自旋比较来确保数据的一致性.
public final int getAndUpdate(IntUnaryOperator updateFunction) {
int prev, next;
do {
prev = get();
next = updateFunction.applyAsInt(prev);
} while (!compareAndSet(prev, next));
return prev;
}
java源码里面调用native方法
public final native boolean compareAndSwapInt(Object var1, long var2, int var4, int var5);
通过Hostpot源码发现其实底层调用操作系统cmpxchg指令完成的比较和交换,但是这个指令不是原子性的,所以通过lock指令来保证原子性。
在unsafe.cpp源码中我们看到最总是调用Atomic的cmpxchg方法来实现的,我们在追到Atomic的cmpxchg方法中,如下:
asm表示是汇编语言,cmpxchg(compare and exchange)是一条汇编指令,这个表明cas在硬件上就能直接支持的。