激情久久久_欧美视频区_成人av免费_不卡视频一二三区_欧美精品在欧美一区二区少妇_欧美一区二区三区的

服務器之家:專注于服務器技術及軟件下載分享
分類導航

PHP教程|ASP.NET教程|Java教程|ASP教程|編程技術|正則表達式|C/C++|IOS|C#|Swift|Android|VB|R語言|JavaScript|易語言|vb.net|

服務器之家 - 編程語言 - Java教程 - 詳解Java多線程tryLock()方法使用

詳解Java多線程tryLock()方法使用

2022-03-06 00:44不高興就喝水叭 Java教程

本文主要介紹了Java多線程tryLock()方法,文中通過示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下

tryLock(long time, TimeUnit unit) 的作用在給定等待時長內鎖沒有被另外的線程持有,并且當前線程也沒有被中斷,則獲得該鎖,通過該方法可以實現鎖對象的限時等待。

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
package com.wkcto.lock.reentrant;
 
import java.util.concurrent.TimeUnit;
import java.util.concurrent.locks.ReentrantLock;
 
/**
 *tryLock(long time, TimeUnit unit) 的基本使用
 */
public class Test07 {
    static class TimeLock implements Runnable{
        private static ReentrantLock lock = new ReentrantLock();    //定義鎖對象
 
        @Override
        public void run() {
            try {
                if ( lock.tryLock(3, TimeUnit.SECONDS) ){       //獲得鎖返回true
                    System.out.println(Thread.currentThread().getName() + "獲得鎖,執行耗時任務");
//                    Thread.sleep(4000);         //假設Thread-0線程先持有鎖,完成任務需要4秒鐘,Thread-1線程嘗試獲得鎖,Thread-1線程在3秒內還沒有獲得鎖的話,Thread-1線程會放棄
                    Thread.sleep(2000);          //假設Thread-0線程先持有鎖,完成任務需要2秒鐘,Thread-1線程嘗試獲得鎖,Thread-1線程會一直嘗試,在它約定嘗試的3秒內可以獲得鎖對象
                }else {         //沒有獲得鎖
                    System.out.println(Thread.currentThread().getName() + "沒有獲得鎖");
                }
            } catch (InterruptedException e) {
                e.printStackTrace();
            } finally {
                if (lock.isHeldByCurrentThread()){
                    lock.unlock();
                }
            }
        }
    }
 
    public static void main(String[] args) {
        TimeLock timeLock = new TimeLock();
 
        Thread t1 = new Thread(timeLock);
        Thread t2 = new Thread(timeLock);
        t1.start();
        t2.start();
    }
}

tryLock()僅在調用時鎖定未被其他線程持有的鎖,如果調用方法時,鎖對象對其他線程持有,則放棄,調用方法嘗試獲得沒,如果該鎖沒有被其他線程占用則返回true表示鎖定成功; 如果鎖被其他線程占用則返回false,不等待。

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
package com.wkcto.lock.reentrant;
 
import java.util.concurrent.locks.ReentrantLock;
 
/**
 *tryLock()
 *  當鎖對象沒有被其他線程持有的情況下才會獲得該鎖定
 */
public class Test08 {
    static class Service{
        private ReentrantLock lock = new ReentrantLock();
        public void serviceMethod(){
            try {
                if (lock.tryLock()){
                    System.out.println(Thread.currentThread().getName() + "獲得鎖定");
                    Thread.sleep(3000);     //模擬執行任務的時長
                }else {
                    System.out.println(Thread.currentThread().getName() + "沒有獲得鎖定");
                }
            } catch (InterruptedException e) {
                e.printStackTrace();
            } finally {
                if (lock.isHeldByCurrentThread()){
                    lock.unlock();
                }
            }
        }
    }
 
    public static void main(String[] args) throws InterruptedException {
        Service service = new Service();
        Runnable r = new Runnable() {
            @Override
            public void run() {
                service.serviceMethod();
            }
        };
 
        Thread t1 = new Thread(r);
        t1.start();
        Thread.sleep(50);       //睡眠50毫秒,確保t1線程鎖定
        Thread t2 = new Thread(r);
        t2.start();
    }
}
?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
package com.wkcto.lock.reentrant;
 
import java.util.Random;
import java.util.concurrent.locks.ReentrantLock;
 
/**
 * 使用tryLock()可以避免死鎖
 */
public class Test09 {
    static class  IntLock implements Runnable{
        private static ReentrantLock lock1 = new ReentrantLock();
        private static ReentrantLock lock2 = new ReentrantLock();
        private int lockNum;        //用于控制鎖的順序
 
        public IntLock(int lockNum) {
            this.lockNum = lockNum;
        }
 
        @Override
        public void run() {
            if ( lockNum % 2 == 0 ){    //偶數先鎖1,再鎖2
                while (true){
                    try {
                        if (lock1.tryLock()){
                            System.out.println(Thread.currentThread().getName() + "獲得鎖1, 還想獲得鎖2");
                            Thread.sleep(new Random().nextInt(100));
 
                            try {
                                if (lock2.tryLock()){
                                    System.out.println(Thread.currentThread().getName() + "同時獲得鎖1與鎖2 ----完成任務了");
                                    return;         //結束run()方法執行,即當前線程結束
                                }
                            } finally {
                                if (lock2.isHeldByCurrentThread()){
                                    lock2.unlock();
                                }
                            }
                        }
                    } catch (InterruptedException e) {
                        e.printStackTrace();
                    } finally {
                        if (lock1.isHeldByCurrentThread()){
                            lock1.unlock();
                        }
                    }
                }
            }else {     //奇數就先鎖2,再鎖1
                while (true){
                    try {
                        if (lock2.tryLock()){
                            System.out.println(Thread.currentThread().getName() + "獲得鎖2, 還想獲得鎖1");
                            Thread.sleep(new Random().nextInt(100));
 
                            try {
                                if (lock1.tryLock()){
                                    System.out.println(Thread.currentThread().getName() + "同時獲得鎖1與鎖2 ----完成任務了");
                                    return;         //結束run()方法執行,即當前線程結束
                                }
                            } finally {
                                if (lock1.isHeldByCurrentThread()){
                                    lock1.unlock();
                                }
                            }
                        }
                    } catch (InterruptedException e) {
                        e.printStackTrace();
                    } finally {
                        if (lock2.isHeldByCurrentThread()){
                            lock2.unlock();
                        }
                    }
                }
            }
        }
    }
    public static void main(String[] args) {
        IntLock intLock1 = new IntLock(11);
        IntLock intLock2 = new IntLock(22);
        Thread t1 = new Thread(intLock1);
        Thread t2 = new Thread(intLock2);
        t1.start();
        t2.start();
        //運行后,使用tryLock()嘗試獲得鎖,不會傻傻的等待,通過循環不停的再次嘗試,如果等待的時間足夠長,線程總是會獲得想要的資源
    }
}

到此這篇關于詳解Java多線程tryLock()方法使用的文章就介紹到這了,更多相關Java tryLock()內容請搜索服務器之家以前的文章或繼續瀏覽下面的相關文章希望大家以后多多支持服務器之家!

原文鏈接:https://juejin.cn/post/7023267765918105630

延伸 · 閱讀

精彩推薦
主站蜘蛛池模板: 成品片a免费直接观看 | 国产三级精品最新在线 | 亚洲一区免费观看 | 免费黄色在线电影 | 精品国产一区二区三区四区在线 | 国产a一级片 | aa级黄色片 | 久成人 | 亚洲国产网站 | 欧美日韩亚洲精品一区二区三区 | 日本一道aⅴ不卡免费播放 久久久久久久高清 | 中国产一级毛片 | av免费在线播放网址 | 高潮激情aaaaa免费看 | 国产精品视频免费网站 | 日本不卡一二三区 | 国产一区二区精品在线观看 | 国产成人免费精品 | 国产午夜亚洲精品午夜鲁丝片 | 日韩黄色成人 | 九九热免费观看 | 久久久综合 | h视频免费在线观看 | 18欧美性xxxx极品hd | 色99久久 | 国产九色视频在线观看 | 爱逼av | 精品一区二区久久久 | 欧美精品一二三区 | 精品国产一区二区三区四区阿崩 | 久久影院免费观看 | 欧洲狠狠鲁 | 日韩欧美电影在线观看 | 国产羞羞视频免费在线观看 | av不卡毛片 | 91精品国产777在线观看 | 91精品国啪老师啪 | 激情综合在线 | 色综合一区二区 | 49vvv | 国产1区2|