java 同步锁_java线程中的同步锁和互斥锁有什么区别?
生活随笔
收集整理的這篇文章主要介紹了
java 同步锁_java线程中的同步锁和互斥锁有什么区别?
小編覺得挺不錯的,現在分享給大家,幫大家做個參考.
在java中,同步鎖和互斥鎖英文關鍵字都是Synchronized,沒有本質上的區別,兩者都包括對資源的獨占,使用起來沒有區別。概念上的區別是
1:互斥是通過競爭對資源的獨占使用,彼此沒有什么關系,執行順序是一個亂序,沒有固定的執行順序。
2:同步是協調多個相互關聯線程合作完成任務,彼此之間知道對方存在,執行順序往往是有序的。線程通過一定的邏輯順序占有資源,有一定的合作關系去完成任務。
由于同步鎖和互斥鎖在使用中沒有任何區別,僅僅是因為線程的關系導致了概念上的一點點區別,所以不必深究其異同。很多教程中并沒有對這兩者作區分。
下面通過一個實例來掌握同步鎖的原理和使用方法。先來執行一下如下沒有加鎖的代碼:
public class LockDemo { private int i = 0; public void increaseI() { // synchronized (this) { for(int k=1;k<=10;k++) { // 對i執行10次增1操作 i++;i--;i++;i--;i++;i--;i++;i--;i++;i--;i++;i--;i++;i--;i++;i--;i++;i--; i++; } System.out.println(Thread.currentThread().getName() + "線程,i現在的值:" + i); //} } public static void main(String[] args) throws InterruptedException { LockDemo ld = new LockDemo(); int threadNum = 1000; MyThread[] threads = new MyThread[threadNum]; for(int i=0;i代碼預期的結果為10000。實際輸出結果不到10000。
沒有加互斥鎖
這是因為1000個線程共享了對象ld的屬性i,在訪問修改i的值時,可能會出現不同步的情況。
線程的同步(互斥)正是為了防止多個線程訪問一個數據對象時,對數據造成的破壞:去掉第4行和第10行的注釋,給increaseI()方法加鎖后,各個線程對變量i的訪問就是互斥的了,就不會對數據造成無法預估的結果:輸出結果為預期的10000。
總結
以上是生活随笔為你收集整理的java 同步锁_java线程中的同步锁和互斥锁有什么区别?的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 社保银行卡怎么激活
- 下一篇: python魅力_魅力python---