像synchronized关键字控制这样的锁是非公平的,因为系统只会从这个锁的等待队列中随机选择一个。而公平锁的特点就是按照时间先后顺序或许锁执行。
Demo如下:
import java.util.concurrent.locks.Condition; import java.util.concurrent.locks.ReentrantLock; /** * 公平锁: 对同一个临界区资源进行访问的所有线程按时间顺序先后执行 */ public class TestFair implements Runnable{ private ReentrantLock lock = new ReentrantLock(true); //如果为true 则启用公平锁模式 @Override public void run(){ for(int i = 0; i < 10; i++){ lock.lock(); System.out.println(Thread.currentThread().getName() + ":" +i); try { Thread.sleep(100); } catch (InterruptedException e) { e.printStackTrace(); } lock.unlock(); } } public static void main(String[] args){ TestFair testFair = new TestFair(); Thread t1 = new Thread(testFair, "t1"); Thread t2 = new Thread(testFair, "t2"); t1.start(); t2.start(); } }
结果:
t1:0
t2:0
t1:1
t2:1
t1:2
t2:2
t1:3
t2:3
t1:4
t2:4
t1:5
t2:5
t1:6
t2:6
t1:7
t2:7
t1:8
t2:8
t1:9
t2:9
两个线程交替执行。