图中的 synchronized方法如果没有锁,那么可能会有超卖,数据错误等情况。
加锁之后会按顺序售卖。
synchronized的底层是monitor。
线程没有竞争关系的时候,引入了轻量级锁,当需要处理竞争关系的时候一定要用到重量级锁(线程的对象锁)。
mark word中重量级锁时,ptr_to_heavyweight_monitor是一个指向monitor的指针。
cas交换是用来保证原子操作的.
👆cas会做交换,交换地址值,这样其他线程就无法获取锁,但是自己的线程内可以多次获取锁(没有竞争关系时)。
在Java中,轻量级锁(Lightweight Locking)和偏向锁(Biased Locking)是Java虚拟机(JVM)内部实现的锁优化技术,它们旨在提高多线程环境下锁的性能。这些锁策略是JVM自动管理的,通常不需要开发者手动开启或关闭。
线程里面的工作内存不存在线程安全的问题,共享变量副本是主内存中共享变量的副本,需要通过JMM控制进行save和load
👆在上面这段代码中,线程1修改的stop为true,线程2是能读到的,但是线程3while循环却不停止。
JVM优化导致的重排序。
实验数据
👆这个可以解决问题
👆这个不能组织x在y后执行,不能解决问题。
AQS的实现类当中,公平锁和非公平锁都有实现。
一把锁,获取效率很低
每个hash值都有一把锁。
Linked效率高一点(两把锁),因为可以分别控制输入输出。而array只有一把锁,输入输出同时控制。
👆可以一直创造线程。
使用线程池子来进行多线程的复用就可以达到上图中右边的效果。
上图为上上图中利用线程池执行的线程逻辑代码。
上图中保存搜索历史记录使用的异步调用。
taskExecutor是一个已经定义的线程池。
ThreadLocal中线程之间数据是不互通的。通过以上样例可以看出。