内存模型
cpu-寄存器-高速缓存-内存
栈帧区:存放变量名或者基本数据类型(线程独有)
堆区:存放对象
方法区:存放类信息、常量、静态对象
本地区:本地方希区
程序计数器
线程安全
volitile:如何保证的可见性,有序性、不能保证原子性(不依赖当前变量的值)
同步锁synchronized(偏向锁、轻量级锁(自旋锁)、重量级锁)
信号:可以控制并发数
原子类:可以保证院子里类对象的线程安全,原理是什么呢
ThreadLocal:线程独立变量
集合:
同步集合类
并发集合包
ReentrainLock:相比同步锁、能够更家灵活地控制锁的释放。
copyAndWrite:允许多个线程以非同步的方式读,当有线程写的时候它会将整个List复制一个副本给它。如果在读多写少这种对并发集合有利的条件下使用并发集合
ConcurrentHashMap:把整个Map 划分成几个片段,只对相关的几个片段上锁,同时允许多线程访问其他未上锁的片段。Sengment:将集合分成一段段,每一段加锁。
协程
Object.wait/notify:调用wait当前线程进入等待状态,直到调用notify线程进入进入阻塞状态,再次获得锁后从原先等待的地方开始运行。
Thread.join:如在A线程执行B线程的join方法,相当于让A线程等待B,B线程执行完后会隐式的通知B,此时A会解除等待恢复执行。
sleep