• ReentrantLock


    package com.dh.test;
    
    import java.util.concurrent.TimeUnit;
    import java.util.concurrent.locks.ReentrantLock;
    
    public class ReentrantLockTest {
        // 参考:https://www.cnblogs.com/takumicx/p/9338983.html
        // ReentrantLock 可重入锁   有lock必须有对应的unlock
        // ReentrantLock  公平锁FairSync()  非公平锁NonfairSync()  非公平锁性能更好,但是当有足够多的的线程时,可能会造成饥饿问题(长时间获取不到锁)
        // ReentrantLock lockInterruptibly() 可响应中断。 如下造成死锁时,中断thread1,可让thread2正常执行
        // ReentrantLock tryLock()  可选择时间参数,表示等待指定时间,无参表示立即返回获取锁的结果:true表示获取锁成功,false表示获取锁失败
        // 线程间通信,Object的wait/notify方法   ReentrantLock可newCondition() ,利用condition的await/single()来进行线程间通信,await会释放当前锁。
    
    
        static ReentrantLock lock1 = new ReentrantLock();
        static ReentrantLock lock2 = new ReentrantLock();
        static ReentrantLock lock3 = new ReentrantLock();
        static ReentrantLock lock4 = new ReentrantLock();
    
        public static void main(String[] args) throws InterruptedException {
            Thread thread1 = new Thread(new MyThread(lock1, lock2));
            Thread thread2 = new Thread(new MyThread(lock2, lock1));
            thread1.start();
            thread2.start();
            thread1.interrupt();
    
            Thread.sleep(100);
    
            Thread try1 = new Thread(new TryLockThread(lock3, lock4));
            Thread try2 = new Thread(new TryLockThread(lock4, lock3));
            try1.start();
            try2.start();
        }
    
        //响应中断的代码示例:lockInterruptibly()
        static class MyThread implements Runnable {
            ReentrantLock lock1;
            ReentrantLock lock2;
    
            public MyThread(ReentrantLock lock1, ReentrantLock lock2) {
                this.lock1 = lock1;
                this.lock2 = lock2;
            }
    
            @Override
            public void run() {
                try {
                    lock1.lockInterruptibly();
                    Thread.sleep(10);
                    lock2.lockInterruptibly();
                } catch (InterruptedException e) {
                    e.printStackTrace();
                } finally {
                    lock1.unlock();
                    lock2.unlock();
                }
            }
        }
    
        static class TryLockThread implements Runnable {
            ReentrantLock lock1;
            ReentrantLock lock2;
    
            public TryLockThread(ReentrantLock lock1, ReentrantLock lock2) {
                this.lock1 = lock1;
                this.lock2 = lock2;
            }
    
            @Override
            public void run() {
    
                try {
                    while (!lock1.tryLock()) {
                        TimeUnit.MILLISECONDS.sleep(10);
                    }
                    while (!lock2.tryLock()) {
                        lock1.unlock();
                        TimeUnit.MILLISECONDS.sleep(10);
                    }
                    System.out.println("tryLock==线程执行完毕");
                } catch (InterruptedException e) {
                    e.printStackTrace();
                } finally {
                    lock1.unlock();
                    lock2.unlock();
                }
    
            }
        }
    }
  • 相关阅读:
    17年day4
    11.7NOIP模拟题
    P3389 【模板】高斯消元法
    洛谷 P2136 拉近距离 题解
    浅谈SPFA判负环
    洛谷 P1629 邮递员送信 题解
    洛谷 P1821 [USACO07FEB]银牛派对Silver Cow Party 题解
    洛谷 P3905 道路重建 题解
    洛谷 P1351 联合权值 题解
    洛谷 P4779 【模板】单源最短路径(标准版) 题解
  • 原文地址:https://www.cnblogs.com/han6/p/11263151.html
Copyright © 2020-2023  润新知