真实的国产乱ⅩXXX66竹夫人,五月香六月婷婷激情综合,亚洲日本VA一区二区三区,亚洲精品一区二区三区麻豆

成都創(chuàng)新互聯(lián)網(wǎng)站制作重慶分公司

javasynchronized實現(xiàn)可見性過程解析

JMM關(guān)于synchronized的兩條規(guī)定:

成都創(chuàng)新互聯(lián)公司是專業(yè)的滁州網(wǎng)站建設(shè)公司,滁州接單;提供網(wǎng)站設(shè)計、做網(wǎng)站,網(wǎng)頁設(shè)計,網(wǎng)站設(shè)計,建網(wǎng)站,PHP網(wǎng)站建設(shè)等專業(yè)做網(wǎng)站服務(wù);采用PHP框架,可快速的進行滁州網(wǎng)站開發(fā)網(wǎng)頁制作和功能擴展;專業(yè)做搜索引擎喜愛的網(wǎng)站,專業(yè)的做網(wǎng)站團隊,希望更多企業(yè)前來合作!

1)線程解鎖前,必須把共享變量的最新值刷新到主內(nèi)存中

2)線程加鎖時,將清空工作內(nèi)存中共享變量的值,從而使用共享變量時需要從主內(nèi)存中重新獲取最新的值

(注意:加鎖與解鎖需要是同一把鎖)

通過以上兩點,可以看到synchronized能夠?qū)崿F(xiàn)可見性。同時,由于synchronized具有同步鎖,所以它也具有原子性

多線程中程序交錯執(zhí)行時,重排序可能會造成內(nèi)存可見性問題

接下來我們看一段代碼:

/**
 * synchronized能夠?qū)崿F(xiàn)原子性(同步)、可見性
 * 
 * @author xuwenjin
 */
public class SynchronizedDemo {
  //共享變量
  private boolean ready = false;
  private int result = 0;
  private int number = 1;
  /**
   * 寫操作
   */
  public void write() {
    ready = true; //1.1
    number = 2;  //1.2
  }
  /**
   * 讀操作
   */
  public void read() {
    if (ready) {       //2.1
      result = number * 3; //2.2
    }
    System.out.println("result:" + result);
  }
  //內(nèi)部線程類
  private class WriteReadThread extends Thread {
    
    private boolean flag = false;    
    public WriteReadThread(boolean flag){
      this.flag = flag;
    }    
    @Override
    public void run() {
      if (flag) {
        write();
      }else {
        read();
      }
    }
  }
  public static void main(String[] args) {
    SynchronizedDemo demo = new SynchronizedDemo();
    //啟動線程執(zhí)行寫操作
    demo.new WriteReadThread(true).start();
    //啟動線程執(zhí)行讀操作
    demo.new WriteReadThread(false).start();
  }
}

上面的代碼可能出現(xiàn)如下執(zhí)行順序:

1) 1.1 --> 1.2 --> 2.1--> 2.2 result的值為6 (正常情況)

2) 1.1 --> 2.1 --> 2.2 --> 1.2 result的值為3 (當(dāng)寫線程執(zhí)行完1.1之后,讀線程開始)

3) 1.2 --> 2.1 --> 2.2 --> 1.1 result的值為0 (1.1跟1.2重排序)

4)...

當(dāng)然由于重排序和線程的交叉執(zhí)行,還可能出現(xiàn)很多種執(zhí)行順序

導(dǎo)致共享變量在線程間不可見的原因:

  •   a、線程的線程執(zhí)行
  •   b、重排序結(jié)合線程交叉執(zhí)行
  •   c、共享變量更新后的值沒有在工作內(nèi)存與主內(nèi)存間及時更新

那么如何解決可見性的問題呢?接下來我們的主角出場:synchronized

安全的代碼:

/**
   * 寫操作
   */
  public synchronized void write() {
    ready = true; //1.1
    number = 2;  //1.2
  }
  /**
   * 讀操作
   */
  public synchronized void read() {
    if (ready) {       //2.1
      result = number * 3; //2.2
    }
    System.out.println("result:" + result);
  }

由于synchronized的原子性、可見性,可以完美解決以上說的三點問題。不過讀線程和寫線程的執(zhí)行順序是不定的,所以result的結(jié)果仍然會出現(xiàn)6或0。

以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持創(chuàng)新互聯(lián)。


網(wǎng)頁題目:javasynchronized實現(xiàn)可見性過程解析
分享網(wǎng)址:http://weahome.cn/article/godijh.html

其他資訊

在線咨詢

微信咨詢

電話咨詢

028-86922220(工作日)

18980820575(7×24)

提交需求

返回頂部