大战熟女丰满人妻av-荡女精品导航-岛国aaaa级午夜福利片-岛国av动作片在线观看-岛国av无码免费无禁网站-岛国大片激情做爰视频

Java多線程編程概述
Java多線程的安全問(wèn)題
Java多線程同步
Java多線程間的通信
Java線程Lock
Java多線程管理
保障線程安全的設(shè)計(jì)技術(shù)
Java鎖的優(yōu)化及注意事項(xiàng)
Java多線程集合
【Java多線程】單例模式與多線程

Java多線程:tryLock()方法

tryLock(long time, TimeUnit unit) 的作用在給定等待時(shí)長(zhǎng)內(nèi)鎖沒(méi)有被另外的線程持有,并且當(dāng)前線程也沒(méi)有被中斷,則獲得該鎖,通過(guò)該方法可以實(shí)現(xiàn)鎖對(duì)象的限時(shí)等待。

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();    //定義鎖對(duì)象

        @Override
        public void run() {
            try {
                if ( lock.tryLock(3, TimeUnit.SECONDS) ){       //獲得鎖返回true
                    System.out.println(Thread.currentThread().getName() + "獲得鎖,執(zhí)行耗時(shí)任務(wù)");
//                    Thread.sleep(4000);         //假設(shè)Thread-0線程先持有鎖,完成任務(wù)需要4秒鐘,Thread-1線程嘗試獲得鎖,Thread-1線程在3秒內(nèi)還沒(méi)有獲得鎖的話,Thread-1線程會(huì)放棄
                    Thread.sleep(2000);          //假設(shè)Thread-0線程先持有鎖,完成任務(wù)需要2秒鐘,Thread-1線程嘗試獲得鎖,Thread-1線程會(huì)一直嘗試,在它約定嘗試的3秒內(nèi)可以獲得鎖對(duì)象
                }else {         //沒(méi)有獲得鎖
                    System.out.println(Thread.currentThread().getName() + "沒(méi)有獲得鎖");
                }
            } 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()僅在調(diào)用時(shí)鎖定未被其他線程持有的鎖,如果調(diào)用方法時(shí),鎖對(duì)象對(duì)其他線程持有,則放棄,調(diào)用方法嘗試獲得沒(méi),如果該鎖沒(méi)有被其他線程占用則返回true表示鎖定成功; 如果鎖被其他線程占用則返回false,不等待。

package com.wkcto.lock.reentrant;

import java.util.concurrent.locks.ReentrantLock;

/**
 *tryLock()
 *  當(dāng)鎖對(duì)象沒(méi)有被其他線程持有的情況下才會(huì)獲得該鎖定
 */
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);     //模擬執(zhí)行任務(wù)的時(shí)長(zhǎng)
                }else {
                    System.out.println(Thread.currentThread().getName() + "沒(méi)有獲得鎖定");
                }
            } 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();
    }
}
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 ){    //偶數(shù)先鎖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() + "同時(shí)獲得鎖1與鎖2 ----完成任務(wù)了");
                                    return;         //結(jié)束run()方法執(zhí)行,即當(dāng)前線程結(jié)束
                                }
                            } finally {
                                if (lock2.isHeldByCurrentThread()){
                                    lock2.unlock();
                                }
                            }
                        }
                    } catch (InterruptedException e) {
                        e.printStackTrace();
                    } finally {
                        if (lock1.isHeldByCurrentThread()){
                            lock1.unlock();
                        }
                    }
                }
            }else {     //奇數(shù)就先鎖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() + "同時(shí)獲得鎖1與鎖2 ----完成任務(wù)了");
                                    return;         //結(jié)束run()方法執(zhí)行,即當(dāng)前線程結(jié)束
                                }
                            } 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();
        //運(yùn)行后,使用tryLock()嘗試獲得鎖,不會(huì)傻傻的等待,通過(guò)循環(huán)不停的再次嘗試,如果等待的時(shí)間足夠長(zhǎng),線程總是會(huì)獲得想要的資源
    }
}

 

全部教程
主站蜘蛛池模板: 日韩欧美在线播放视频 | 欧美性在线播放 | 国产在线精彩视频 | 国产精品久久久久久久hd | 欧美成人免费全网站大片 | 人人爱天天做夜夜爽2020麻豆 | 99视频精品全部 在线 | 久久精品成人一区二区三区 | 看全色黄大色大片免费视频 | 欧美一欧美一区二三区性 | 久久91精品国产91久久 | chinese国产在线视频 | 亚洲国产九九精品一区二区 | 日韩欧美国产亚洲 | 精品一区二区在线欧美日韩 | 国产亚洲精品福利 | 久久99热只有视精品6国产 | 2021国产精品系列一区二区 | 国产日韩精品欧美一区色 | 日本免费一区二区三区看片 | 香蕉久久夜色精品国产 | 乱码一区二区三区完整视频 | 日日夜夜免费视频 | 人人草影院 | 亚洲国产中文字幕 | 99久久99久久 | 成人a毛片免费全部播放 | 国产婷婷高清在线观看免费 | 精品福利一区二区三区免费视频 | 国产伦一区二区三区免费 | a毛片在线免费观看 | 午夜香蕉成视频人网站高清版 | 日本在线观看www | 看免费5xxaaa毛片30厘米 | 偶偶福利视频 | 精品无码久久久久久久动漫 | 日本久久伊人 | 亚洲欧美在线看 | 日本a中文字幕 | 成人国产精品视频频 | 国产成人免费a在线视频色戒 |