在多線程對一個整數(shù)進行自增操作時,需要用synchronized進行同步。然而,如果synchronized的對象選取的不合適的話,就無法實現(xiàn)同步的效果。如下面的例子。
創(chuàng)新互聯(lián)建站專注于南鄭企業(yè)網(wǎng)站建設(shè),響應(yīng)式網(wǎng)站建設(shè),商城網(wǎng)站制作。南鄭網(wǎng)站建設(shè)公司,為南鄭等地區(qū)提供建站服務(wù)。全流程按需搭建網(wǎng)站,專業(yè)設(shè)計,全程項目跟蹤,創(chuàng)新互聯(lián)建站專業(yè)和態(tài)度為您提供的服務(wù)
public class SyncThreadTest extends Thread { public static Integer count = 0; private static final int TIMES = 10000; public SyncThreadTest(){ super("SyncThread"); } @Override public void run(){ synchronized (count){ for (int i = 0; i < TIMES; i ++){ count++; } } } public static void main(String[] args) throws InterruptedException{ SyncThreadTest t1 = new SyncThreadTest(); SyncThreadTest t2 = new SyncThreadTest(); t1.start(); t2.start(); t1.join(); t2.join(); System.out.println(count); } }
在上面的例子中,選取了自增的變量作為同步的對象。啟動2個線程,各自對count自增10000次。最后的結(jié)果,count的值卻不是20000次。
原因在于count對象一直處于改變當(dāng)中,起不到兩個線程的鎖的作用。
總結(jié)
以上就是這篇文章的全部內(nèi)容了,希望本文的內(nèi)容對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,謝謝大家對創(chuàng)新互聯(lián)的支持。如果你想了解更多相關(guān)內(nèi)容請查看下面相關(guān)鏈接