Fork me on GitHub

Java并发互斥同步

Java提供两种锁机制控制多线程对互斥资源的互斥访问,一种是JVM实现的synchronized,一种是JDK实现的RentranLock.

synchronized

  • 同步一个代码块;只作用于一个对象,如果调用两个不同的对象上的同步代码块,不会进行同步;

    1
    2
    3
    4
    5
    6
    7
    8
    9
    public class SynchronizedExample {
    public void func1() {
    synchronized (this) {
    for (int i = 0; i < 10; i++) {
    System.out.print(i + " ");
    }
    }
    }
    }
  • 同步一个方法;和同步代码块一样,只作用于相同对象;

    1
     
  • 同步一个类;作用于整个类,即两个线程调用同一类的不同对象上的同步语句,也会进行同步;

    1
    2
    3
    4
    5
    6
    public void func() {
    synchronized (SynchronizedExample.class) {
    // ...
    }

    }
  • 同步一个静态方法;作用于整个类

    1
    2
    3
    public synchronized static void fun() {
    // ...
    }

RentranLock

RentranLockjava.util.concurrent(J.U.C)包中的锁;
Java并发之ReentrantLock详解

两者的异同

  • 锁的实现;synchronized是JVM实现,RentranLock是JDK实现
  • 性能:由于新版本Java对synchronized进行了很多 优化 ,例如自旋锁等,两者性能大致相同
  • 等待可中断;当一个线程长期不释放锁时,其他在等待的线程可以放弃等待去处理其他事情;RentranLock可中断,而synchronized`不行
  • 公平锁;即当多个线程在等待同一锁时,必须按照申请锁的时间顺序获得锁;synchronized中的锁是非公平的;RentranLock默认的锁也是不公平的,但是也可以是公平的
  • 绑定条件;一个RentranLock可以绑定多个Condition对象。 在一个锁中使用多个条件(Condition)
-------------本文结束感谢您的阅读-------------