高并发编程
并发:多个线程操作相同的资源,保证线程安全,合理使用资源。
高并发:服务能同时处理很多请求,提高程序性能。
Java内存模型(Java Memory Model,JMM)
堆:可以动态的生成内存大小,垃圾收集器会自动回收,存储速度慢。
栈:存储块,仅次于计数器,存在的大小必须固定。
Java内存模型同步八种操作
锁定(Lock)
作为与主内存的变量,把一个变量标识为一条线程独占状态。
解锁(unlock)
作用于主内存的变量,把一个处于锁定状态的变量释放出来,释放后的变量菜可以被其他线程锁定。
read(读取)
作用于主内存的变量,把一个变量值从主内存传输到线程的工作内存中,以便以后的load动作使用。
load(载入)
作用于工作内存的变量,它把read操作从主内存中得到的变量值放入工作内存的变量副本中。
use(使用)
作用于工作内存的变量,把工作内存中的一个变量值传递给执行引擎。
assign(赋值)
作用于工作内存的变量,它把一个从执行引擎接收到的值赋给工作内存的变量。
store(存储)
作用于工作内存的变量,把工作内存中的一个变量的值传送到主内存中,以便随后的wirte的操作。
write(写入)
作用于主内存的变量,它把store操作从工作内存中的一个变量的值传送到主内存的变量中。
并发的优势与风险
优势:速度,设计,资源利用。
风险:安全性,活跃性,性能。
总结
CPU多级缓存:缓存一致性,乱序执行优化
java内存模型:JMM规定,抽象结构,同步八种操作及规则。
Java并发的优势与风险