操作系统为每一个进程创建巨大、私有的虚拟内存的假象,这种地址空间的抽象让每个程序觉得自己好像拥有自己的内存,但是实际上操作系统在背后让多个地址空间复用物理内存或者是磁盘。
如果多个线程竞争的是共享资源,如果不采取有效措施,会造成共享数据的混乱。
我们做个小实验,创建两个线程,它们分别对共享变量 i
自增 1
执行 10000
次,结果不是20000
为什么会出现上述问题,我们需要了解编译器给i = i+1,是如何执行的,分为三步:
- 从内存中取出i值后,放入到寄存器中
- 对寄存器中的i值+1
- 把寄存器中的i值放回内存
寄存器是什么东西?寄存器是CPU的上下文环境,线程1运行的时候,它将i的值从内存中加载到它的寄存器中,然后在寄存器中+1,