• 使用Lock对象实现同步效果


    Lock是一个接口,为了使用一个Lock对象,需要用到

     
    Lock lock = new ReentrantLock();
     

    与 synchronized (someObject) 类似的,lock()方法,表示当前线程占用lock对象,一旦占用,其他线程就不能占用了。
    与 synchronized 不同的是,一旦synchronized 块结束,就会自动释放对someObject的占用。 lock却必须调用unlock方法进行手动释放,为了保证释放的执行,往往会把unlock() 放在finally中进行。
    使用Lock对象实现同步效果
     
    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
    package multiplethread;
     
    import java.text.SimpleDateFormat;
    import java.util.Date;
    import java.util.concurrent.locks.Lock;
    import java.util.concurrent.locks.ReentrantLock;
     
    public class TestThread {
     
        public static String now() {
            return new SimpleDateFormat("HH:mm:ss").format(new Date());
        }
     
        public static void log(String msg) {
            System.out.printf("%s %s %s %n", now() , Thread.currentThread().getName() , msg);
        }
     
        public static void main(String[] args) {
            Lock lock = new ReentrantLock();
     
            Thread t1 = new Thread() {
                public void run() {
                    try {
                        log("线程启动");
                        log("试图占有对象:lock");
     
                        lock.lock();
     
                        log("占有对象:lock");
                        log("进行5秒的业务操作");
                        Thread.sleep(5000);
     
                    catch (InterruptedException e) {
                        e.printStackTrace();
                    finally {
                        log("释放对象:lock");
                        lock.unlock();
                    }
                    log("线程结束");
                }
            };
            t1.setName("t1");
            t1.start();
            try {
                //先让t1飞2秒
                Thread.sleep(2000);
            catch (InterruptedException e1) {
                // TODO Auto-generated catch block
                e1.printStackTrace();
            }
            Thread t2 = new Thread() {
     
                public void run() {
                    try {
                        log("线程启动");
                        log("试图占有对象:lock");
     
                        lock.lock();
     
                        log("占有对象:lock");
                        log("进行5秒的业务操作");
                        Thread.sleep(5000);
     
                    catch (InterruptedException e) {
                        e.printStackTrace();
                    finally {
                        log("释放对象:lock");
                        lock.unlock();
                    }
                    log("线程结束");
                }
            };
            t2.setName("t2");
            t2.start();
        }
     
    }
  • 相关阅读:
    C# 设计模式-抽象工厂模式
    C# 设计模式-工厂方法模式
    C# 设计模式-简单工厂模式
    C# 设计原则-迪米特法则(最少知识原则)
    C# 设计原则-接口隔离原则
    阻止右击事件并更改为自定义导航栏;
    今日头条滚动新闻版块特效
    抓包工具
    查看页面加载速度
    插件那点事
  • 原文地址:https://www.cnblogs.com/chinaifae/p/10193903.html
Copyright © 2020-2023  润新知