java多线程-JUC-Look锁了谁?

java多线程-JUC-Look到底锁了谁?

demo

// 代码 
import java.util.concurrent.locks.Lock;
import java.util.concurrent.locks.ReentrantLock;

/*** * ReentrantLock 锁的是 自己内部维护 的 资源 : state * 所有线程 争夺的 是 ReentrantLock 内部的 state 属性的占有权 * */
public class TestReentrantLock extends Thread {
    private  static  DB db = new DB();
    @Override
    public void run() {
        new Thread(new Runnable() {
            @Override
            public void run() {
                db.add();
            }
        }).start();

        new Thread(new Runnable() {
            @Override
            public void run() {
                db.buy();
                db.buy();
            }
        }).start();
        //db.buyNoLook();
    }

    public static void main(String[] args) {
        for (int i = 0; i < 20; i++) {
            new TestReentrantLock().start();
        }
    }

}

//代码锁,非数据库锁
class DB {
    private Lock lock = new ReentrantLock();
    private Lock lock_add = new ReentrantLock();
    // 用static表示该锁是该对象实例共享的

     int i = 100;
    // 用static表示该变量是对象实例共享的

    //加锁 减库存
    public void buy() {
        lock.lock();
        try{
            System.out.println("购买:"+(--i));
        } finally {
            lock.unlock();
        }
    }

     /** * 功能描述: * 必须是同一个 look 锁,才能对 i 有锁住效果 * look 可以用在不同的方法块中 * lock_add 和 look 的使用,相互没有影响 * TODO * @CreateTime [2018/10/22 0022 11:18] * @Param */
    public void add() {
        lock.lock();
        //lock_add.lock();
        try{
            System.out.println("进货:"+(++i));
        } finally {
            lock.unlock();
           // lock_add.unlock();
        }
    }

    //无所 减库存
    public void buyNoLook() {
        i--;
        System.out.println(i);
    }
}

总结

  1. 实例中 class DB 代表数据库
  2. 多个线程同时 去 增加库存 和 减少库存.用 look 去锁;
  3. 必须只能使用 look 一个锁实例;如果 用 lock_add 和 look混搭使用,无效果;
  4. 可以看出 所有线程去调用 look.look()方法时,会产生同步制约(内部是自旋)效果;实质上是所有线程执行到 look.look()方法是,都会去获得 state值;
    原文作者:JUC
    原文地址: https://blog.csdn.net/TianLiaoFeiJue/article/details/83270965
    本文转自网络文章,转载此文章仅为分享知识,如有侵权,请联系博主进行删除。
点赞