午夜剧场伦理_日本一道高清_国产又黄又硬_91黄色网战_女同久久另类69精品国产_妹妹的朋友在线

您的位置:首頁技術文章
文章詳情頁

Java實現線程同步方法及原理詳解

瀏覽:81日期:2022-08-31 17:03:52

一、概述

無論是什么語言,在多線程編程中,常常會遇到多個線同時操作程某個變量(讀/寫),如果讀/寫不同步,則會造成不符合預期的結果。

例如:線程A和線程B并發運行,都操作變量X,若線程A對變量X進行賦上一個新值,線程B仍然使用變量X之前的值,很明顯線程B使用的X不是我們想要的值了。

Java提供了三種機制,解決上述問題,實現線程同步:

同步代碼塊

synchronized(鎖對象){// 這里添加受保護的數據操作}

同步方法

靜態同步方法:synchronized修飾的靜態方法,它的同步鎖是當前方法所在類的字節碼對象

public static synchronized void staticMethod(){}

非靜態同步方法:synchronized修飾的非靜態方法,它的同步鎖即為this

public synchronize void method(){}

鎖機制

// 以可重入鎖舉例Lock lock = new ReentrantLock(/*fail*/); // fail: // true表示使用公平鎖,即線程等待拿到鎖的時間越久,越容易拿到鎖// false表示使用非公平鎖,線程拿到鎖全靠運氣。。。cpu時間片輪到哪個線程,哪個線程就能獲取鎖lock.lock();// 這里添加受保護的數據操作lock.unlock();

個人理解:其實無論哪種機制實現線程同步,本質上都是加鎖->操作數據->解鎖的過程。同步代碼塊是針對{}中,同步方法是針對整個方法。其ReentrantLock類提供的lock和unlock和C++的std::mutex提供lock和unlock類似

二、測試用例

Java實現線程同步方法及原理詳解

同步代碼塊測試類

package base.synchronize;public class SynchronizeBlock implements Runnable { private int num = 100; @Override public void run() { while (num > 1) { synchronized (this) {// 同步代碼塊,只有拿到鎖,才有cpu執行權System.out.println('Thread ID:' + Thread.currentThread().getId() + '---num:' + num);num--; } } System.out.println('Thread ID:' + Thread.currentThread().getId() + ' exit'); }}

同步方法測試類

package base.synchronize;public class SynchronizeMethod implements Runnable { private int num = 100; public static int staticNum = 100; boolean useStaticMethod; public SynchronizeMethod(boolean useStaticMethodToTest) { this.useStaticMethod = useStaticMethodToTest; } // 對于非靜態方法,同步鎖對象即this public synchronized void method() { System.out.println('Thread ID:' + Thread.currentThread().getId() + '---num:' + num); num--; } // 對于靜態方法,同步鎖對象是當前方法所在類的字節碼對象 public synchronized static void staticMethod() { System.out.println('Static Method Thread ID:' + Thread.currentThread().getId() + '---num:' + staticNum); staticNum--; } @Override public void run() { if (useStaticMethod) { // 測試靜態同步方法 while (staticNum > 1) {staticMethod(); } }else{ // 測試非靜態同步方法 while (num > 1){method(); } } System.out.println('Thread ID:' + Thread.currentThread().getId() + ' exit'); }}

ReentrantLock測試類

package base.synchronize;import java.util.concurrent.locks.Lock;import java.util.concurrent.locks.ReentrantLock;public class SynchronizeLock implements Runnable { private Lock lock = null; private int num = 100; public SynchronizeLock(boolean fair){ lock = new ReentrantLock(fair); // 可重入鎖 } @Override public void run() { while (num > 1) { try {lock.lock();System.out.println('Thread ID:' + Thread.currentThread().getId() + '---num:' + num);num--; } catch (Exception e) {e.printStackTrace(); }finally {lock.unlock(); } } System.out.println('Thread ID:' + Thread.currentThread().getId() + ' exit'); }}

測試三種機制的Demo

package base.synchronize;public class Demo { public static void main(String[] args) { synchronizeBlockTest(); // 同步代碼塊 synchronizeMethodTest(); // 同步非靜態方法 synchronizeStaticMethodTest(); // 同步靜態方法 synchronizeLockTest(); // 可重入鎖機制 } public static void synchronizeBlockTest(){ Runnable run = new SynchronizeBlock(); for(int i = 0; i < 3; i++){ new Thread(run).start(); } } public static void synchronizeMethodTest(){ Runnable run = new SynchronizeMethod(false); for(int i = 0; i < 3; i++){ new Thread(run).start(); } } public static void synchronizeStaticMethodTest() { Runnable run = new SynchronizeMethod(true); for(int i = 0; i < 3; i++){ new Thread(run).start(); } } public static void synchronizeLockTest(){ Runnable run = new SynchronizeLock(false); // true:使用公平鎖 false:使用非公平鎖 for(int i = 0; i < 3; i++){ new Thread(run).start(); } }}

無論哪種機制,都得到預期的效果,打印100-0

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持好吧啦網。

標簽: Java
相關文章:
主站蜘蛛池模板: 自拍偷拍第1页 | 在线观看免费黄色片 | 亚洲少妇一区二区 | 伊人久久精品 | 国产精品成人一区二区网站软件 | 色爽网站 | 午夜影院福利社 | 久久99久久99精品免观看粉嫩 | av在线成人 | 亚洲第一页中文字幕 | 久久8| 亚洲高清免费视频 | 国产调教视频在线观看 | 日韩在观看线 | 日韩欧美精品久久 | 久久国产精品偷 | 日本道不卡| 久久久青青 | 超碰久热 | 销魂奶水汁系列小说 | 亚洲性综合 | 中文字幕精品久久 | 亚洲性xxxx | 99久久香蕉 | theporn玉足脚交91 | 国产精品视频成人 | 久久不卡一区 | 成人在线视频一区 | 男女视频h | 一级久久久 | 日韩一区二区三区视频在线观看 | 久久精品国产精品亚洲精品色 | 操天天 | 性高潮免费视频 | 经典三级在线视频 | 国产50页 | 涩涩网站在线观看 | 国产福利资源 | 日本a级片在线观看 | 欧美视频在线一区 | 可以在线观看av的网站 |