java - 線程同步為什么不一樣
問題描述
package com.dome;
public class Thread01 {
private volatile static int a =10;Thread td1 = new Thread(){public void run(){for(int i=0;i<3;i++){ a = a+1;System.out.println(i+'td1:='+a);} } };Thread td2 = new Thread(){ public void run(){for(int i=0;i<3;i++){ a -=1; System.out.println(i+'td2:='+a);} } };public static void main(String[] args) { Thread01 th = new Thread01(); th.td1.start();th.td2.start(); }
}
0td1:=90td2:=91td1:=101td2:=92td1:=102td2:=9
問題解答
回答1:a = a + 1, a = a - 1 這樣的語句,事實上涉及了 讀取-修改-寫入 三個操作:
讀取變量到棧中某個位置
對棧中該位置的值進行加 (減)1
將自增后的值寫回到變量對應的存儲位置
因此雖然變量 a 使用 volatile 修飾,但并不能使涉及上面三個操作的 a = a + 1,a = a - 1具有原子性。為了保證同步性,需要使用 synchronized:
public class Thread01 { private volatile static int a = 10; Thread td1 = new Thread() {public void run() { for (int i = 0; i < 3; i++) {synchronized (Thread01.class) { a = a + 1; System.out.println(i + 'td1:=' + a);} }} }; Thread td2 = new Thread() {public void run() { for (int i = 0; i < 3; i++) {synchronized (Thread01.class) { a -= 1; System.out.println(i + 'td2:=' + a);} }} }; public static void main(String[] args) {Thread01 th = new Thread01();th.td1.start();th.td2.start(); }}
某次運行結果:
(td1 出現的地方,a 就 +1;td2 出現的地方,a 就 -1)
相關文章:
1. angular.js - 如何通俗易懂的解釋“依賴注入”?2. 我在centos容器里安裝docker,也就是在容器里安裝容器,報錯了?3. 老哥們求助啊4. 我的html頁面一提交,網頁便顯示出了我的php代碼,求問是什么原因?5. django - 后臺返回的json數據經過Base64加密,獲取時用python如何解密~!6. html5 - angularjs中外部模版加載無法使用7. css3 - 請問一下在移動端CSS布局布局中通常需要用到哪些元素,屬性?8. tp6表單令牌9. node.js - node 客戶端socket一直報錯Error: read ECONNRESET,用php的socket沒問題哈。。10. ubuntu PPA 更新老是不成功該怎么辦
