上层知识链接:jvm运行机制,CPU与内存的数据交换
下层知识链接:线程不安全的处理方法,synchronized,volatile
线程不安全(不需要了解原理的话把这个看完就够了)
假设售票系统有1000张票,A和B同时来买票,如果是线程不安全,那么可能售票系统可能出现1000-1去同时执行的情况,最终结果是A和B都买完后剩下999张票,而不是998张。
简介
java内存模型简称 JMM(Java Memory Model)
用于模拟CPU真实处理数据交换,为了消除不同系统之间的内存访问差异(原理:系统不同,CPU结构大致相同)
为了提升速度所以出现了一些存取数据不一致的问题,表现在JAVA里就是线程安全问题
首先对比jmm和硬件内存架构
有没有很像???简直一个模子里出来的
堆(heap)对应主存(main memory) 栈(stack)对应寄存器(registers)
CPU会进行数据处理,而数据是从内存里取得的,我们一直这样描述CPU数据交换。
但是随着CPU的处理速度的加快,从内存中存取数据的速度远远达不到CPU需要的要求,所以CPU内