java并发编程之重入锁

心不动则不痛 提交于 2019-11-30 06:09:28

重入锁可以完全替代synchronized关键字,在JDK 5.0早期版本中,重入锁的性能远远好于synchronzied,但是在6.0之后在synchronzied上做了大量的优化,使两者的差距并没那么大的差别。

重入锁使用java.util.concurrent.locks.ReentrantLock类来实现,它只是一个类;

且看如下代码:

package cn.yan.current;

import java.util.concurrent.locks.ReentrantLock;


public class ReenterLock implements Runnable {
    private static ReentrantLock lock = new ReentrantLock();
    public static int i = 0;

    @Override
    public void run() {
        for (int j = 0; j < 30000; j++) {
            lock.lock();
            try {
                i++;
            } finally {
                lock.unlock();
            }
        }
    }


    public static void main(String[] args) throws InterruptedException {
        ReenterLock reenterLock = new ReenterLock();
        Thread t1 = new Thread(reenterLock);
        Thread t2 = new Thread(reenterLock);
        Thread t3 = new Thread(reenterLock);

        t1.start();
        t2.start();
        t3.start();
        t1.join();
        t2.join();
        t3.join();
        System.out.println("i ====>>>> " + i);
    }
}

最终其结果会是什么?显而易见,为90000.

上述代码使用重入锁保护临界区资源i,确保多线程时对i的操作的安全性。从这段代码可以看出,与synchronzied关键字相比,重入锁需要程序员手动的获取锁和释放锁资源。

标签
易学教程内所有资源均来自网络或用户发布的内容,如有违反法律规定的内容欢迎反馈
该文章没有解决你所遇到的问题?点击提问,说说你的问题,让更多的人一起探讨吧!