zoukankan      html  css  js  c++  java
  • Java多线程-Lock的使用(1)

    ReentrantLock类

    在JDK1.5中,新增了 ReentrantLock,相比 synchronized 在扩展功能上更加强大,比如具有嗅探锁定、多路分支通知等功能。

    示例:

    public class Test {
        public static void main(String[] args) {
            MyService service = new MyService();
            new Thread(() -> service.methodA()).start();
            new Thread(() -> service.methodB()).start();
        }
    
        static class MyService {
            private Lock lock = new ReentrantLock();
    
            public void methodA() {
                lock.lock();
                try {
                    System.out.println("methodA begin ThreadName = " + Thread.currentThread().getName() + " time = " + System.currentTimeMillis());
                    Thread.sleep(5000);
                    System.out.println("methodA end ThreadName = " + Thread.currentThread().getName() + " time = " + System.currentTimeMillis());
                } catch (Exception e) {
                    e.printStackTrace();
                } finally {
                    lock.unlock();
                }
            }
    
            public void methodB() {
                lock.lock();
                try {
                    System.out.println("methodB begin ThreadName = " + Thread.currentThread().getName() + " time = " + System.currentTimeMillis());
                    Thread.sleep(5000);
                    System.out.println("methodB end ThreadName = " + Thread.currentThread().getName() + " time = " + System.currentTimeMillis());
                } catch (InterruptedException e) {
                    e.printStackTrace();
                } finally {
                    lock.unlock();
                }
            }
        }
    }

    运行结果如图:

    使用Condition 实现等待/通知

    public class ConditionTest {
        public static void main(String[] args) throws InterruptedException {
            Service service = new Service();
            new Thread(() -> service.await()).start();
            Thread.sleep(3000);
            service.signal();
        }
    
        static class Service {
            private Lock lock = new ReentrantLock();
            private Condition condition = lock.newCondition();
    
            public void await() {
                lock.lock();
                try {
                    System.out.println("begin await 时间为" + System.currentTimeMillis());
                    condition.await();
                    System.out.println("end await 时间为" + System.currentTimeMillis());
                } catch (InterruptedException e) {
                    e.printStackTrace();
                } finally {
                    lock.unlock();
                }
            }
    
            public void signal() {
                lock.lock();
                try {
                    System.out.println("begin signal 时间为" + System.currentTimeMillis());
                    condition.signal();
                    System.out.println("end signal 时间为" + System.currentTimeMillis());
                } finally {
                    lock.unlock();
                }
            }
        }
    }

    运行结果如图:

    使用Condition实现多对多生产者/消费者模式

    public class Test {
        public static void main(String[] args) {
            Service service = new Service();
            for (int i = 0; i < 10; i++) {
                new Thread(() -> {
                    for (int j = 0; j < Integer.MAX_VALUE; j++) {
                        service.set();
                    }
                }).start();
                new Thread(() -> {
                    for (int j = 0; j < Integer.MAX_VALUE; j++) {
                        service.get();
                    }
                }).start();
            }
        }
    
        static class Service {
            private Lock lock = new ReentrantLock();
            private Condition condition = lock.newCondition();
            private boolean hasValue = false;
    
            public void set() {
                lock.lock();
                try {
                    while (hasValue == true) {
                        System.out.println("有可能++连续");
                        condition.await();
                    }
                    System.out.println("打印+");
                    hasValue = true;
                    condition.signalAll();
                } catch (InterruptedException e) {
                    e.printStackTrace();
                } finally {
                    lock.unlock();
                }
            }
    
            public void get() {
                lock.lock();
                try {
                    while (hasValue == false) {
                        System.out.println("有可能**连续");
                        condition.await();
                    }
                    System.out.println("打印*");
                    hasValue = false;
                    condition.signalAll();
                } catch (InterruptedException e) {
                    e.printStackTrace();
                } finally {
                    lock.unlock();
                }
            }
        }
    }

    运行结果如图:

  • 相关阅读:
    ADO数据库操作方式
    C++ 连接Oracle
    ADO 动态链接数据库
    C++连接Oracle之OCCI(windows)
    App测试经验分享之登录注册
    使用dpkg时,提示:dpkg:处理软件包XXX时出错
    性能测试指标及常用的监控工具[转]

    JMeter ——Test fragment
    JMeter设置Http代理对web或者app进行录制
  • 原文地址:https://www.cnblogs.com/lkc9/p/12562590.html
Copyright © 2011-2022 走看看