Java多线程设计模式学习笔记 - Java内存模型

一. 主存储器和工作存储器:

       Java内存模型分为主存储器(mail memory)和工作存储器(working memory)两种, 各自担负不同的功能.

     
1. 主存储器:

 

           实例位置所在的区域, 所有的实例都存在于主存储器内,尤其,实例所拥有的字段即位于主存储器内的区域.

           主存储器为所有的线程共有.

     
2. 工作存储器:

           工作存储器为各个线程所拥有的作业区, 所有的线程都有其专用的工作存储器,在工作存储器内, 存在有主存

          储器中必要部分的拷贝,称为工作拷贝(Working copy).

    
3.  字段(field)的引用:

           线程无法对主存储器直接进行操作,因此它也无法直接引用字段的值.

           当线程欲引用字段的值时,绘出现一下情况:

           <1> 线程或许会引用刚才所制作的字段的工作拷贝.

          <2> 线程也可能会重新从主存储器拷贝字段到工作存储器,然后才会引用这个工作拷贝.

      

    
  4.  指定字段的值:

           线程无法直接对主存储器进行操作,因此他也无法将值直接指定给字段.

           当线程欲将值指定给字段时, 会一次将值指定给位于工作存储器上的工作拷贝(assign),指定完成后, 工作拷

           贝的内容会映象到主存储器,至于何时映射,则由Java执行处理系统来决定.

           当同一个线程反复设置同一个字段值时会发生如下的情况:

           在反复进行指定的期间, 线程有可能指挥对工作拷贝进行指定,此时,只有指定的最后结果会拷贝到主存储器,

           另外,线程也有可能在每次进行指定时,进行拷贝到主存储器的操作. 会出现那种情况由Java执行处理系统来

           决定.

       

     
5. 六个操作:  read , write , use , assign , lock , unlock.

         

         <1> read/write  :  负责主存储器与工作存储器间的atomic action.

                 read – 负责从主存储器拷贝到工作存储器.

                 write – 负责从工作存储器拷贝到主存储器.

         <2> use/assign :  负责线程的执行引行与工作存储器间的atomic action.

                 use – 表示线程引用工作存储器的值.

                assign – 指线程将值指定给工作存储器.

         <3> lock/unLock :  对于伴随着实例而来的锁定, 进行atomic action.

                 lock – 线程取得锁定.

                 unlock – 线程解除锁定.

二. synchornized的两项功能:

      
1. 欲进入synchronized时进行的处理:

           <1> 强制写入主存储器:

                   欲进入synchronized时, 如果工作存储器存在有未映射到主存储器的工作拷贝,该内容则会强制写入

                   主存储器(store->write),因此,之前的计算结果会被全部写入主存储器内, 成为其他县城可以看见的状态.

           <2> 工作存储器释放:

                   欲进入synchronized时, 工作存储器上的工作拷贝会被全部丢弃,之后,欲应用主存储器上的值的线程,必                   定会从主存储器将值拷贝到工作拷贝(read -> load),总之 , 工作存储器的内容欲主存储器的内容会予以

                   同步.

      
2. 欲退出synchronized时进行的处理:

           <1> 强制写入主存储器.(这步和欲进入synchronized进行的处理时一样的).

三. volatile的两项功能:

 

       
1.  进行内存的同步:

             当线程欲引用volatile字段的值时, 通常会发生从主存储器到工作存储器的拷贝操作,而相反的, 将值指定给

              写着volatile的字段后, 工作存储器的内容通常便会映象到主存储器.

        
2. volatile会以atomic的方式进行long , double的指定:

             如果是long型或double型的字段, 只要有写着volatile,就可以用atomic的方式进行指定工作.

    原文作者:java内存模型
    原文地址: https://blog.csdn.net/doudou_bb_08/article/details/2461426
    本文转自网络文章,转载此文章仅为分享知识,如有侵权,请联系博主进行删除。
点赞