java 互斥实现_Java如何实现线程之间的互斥

package com.concurrent.condition;

import java.util.concurrent.locks.Condition;

import java.util.concurrent.locks.Lock;

import java.util.concurrent.locks.ReentrantLock;/*==================================

 * 描述:有3个线程,线程1连续输出3次,然后让线程2连续输出6次,接下来线程3连续输出10次。依次循环10次

 * 

 ==================================*/

public class ConditionExample {public static void main(String[] args) {

final Outer outer = new Outer();

final int loopNum = 10;// 线程1

new Thread(new Runnable() {

@Overridepublic void run() {for (int i = 1; i 

outer.out1(i);

}

}

}).start();// 线程2

new Thread(new Runnable() {

@Overridepublic void run() {for (int i = 1; i 

outer.out2(i);

}

}

}).start();// 线程3

new Thread(new Runnable() {

@Overridepublic void run() {for (int i = 1; i 

outer.out3(i);

}

}

}).start();

}

}class Outer {

Lock lock = new ReentrantLock();

Condition condition1 = lock.newCondition();

Condition condition2 = lock.newCondition();

Condition condition3 = lock.newCondition();int currentNo = 1;// 线程1的输出方法

public void out1(int loopNum) {try {lock.lock();while (currentNo != 1) {try {

condition1.await();

} catch (InterruptedException e) {

e.printStackTrace();

}

}for (int i = 0; i 

System.out.println("this Thread1 outer no." + i + " ; loop="

+ loopNum);

}

currentNo = 2;//标志态置换为线程2可以输出的标志

condition2.signal();// 通知线程2开始了

} finally {lock.unlock();

}

}//线程2的输出方法

public void out2(int loopNum) {try {lock.lock();while (currentNo != 2) {try {

condition2.await();

} catch (InterruptedException e) {

e.printStackTrace();

}

}for (int i = 0; i 

System.out.println("this Thread2 outer no." + i + " ; loop="

+ loopNum);

}

currentNo = 3;//标志态置换为线程3可以输出的标志

condition3.signal();//通知线程3

} finally {lock.unlock();

}

}//线程3的输出方法

public void out3(int loopNum) {try {lock.lock();while (currentNo != 3) {try {

condition3.await();

} catch (InterruptedException e) {

e.printStackTrace();

}

}for (int i = 0; i 

System.out.println("this Thread3 outer no." + i + " ; loop="

+ loopNum);

}

currentNo = 1;//标志态置换为线程2可以输出的标志

condition1.signal();//通知线程1

} finally {lock.unlock();

}

}

}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Java中的互斥锁是通过`ReentrantLock`类来实现的,它的实现原理是基于AQS(AbstractQueuedSynchronizer)同步器的。AQS是一个用于实现同步器的框架,它提供了两种同步状态,分别是独占模式和共享模式。 当一个线程请求锁时,如果锁没有被其他线程占用,则该线程成功获取锁并进入独占模式,此时其他线程再去请求锁时就会被阻塞。如果此时有其他线程已经占用了锁,则当前线程会被加入到一个等待队列中,并且进入阻塞状态。 在`ReentrantLock`中,还提供了可重入特性,也就是说同一个线程可以多次获取同一个锁,而不会被阻塞。这个特性是通过一个计数器来实现的,每当一个线程获取锁时,计数器加1,释放锁时计数器减1,这样同一个线程可以多次获取锁而不会阻塞。 `ReentrantLock`的实现原理主要包括以下几个步骤: 1. 初始化:初始化一个AQS同步器,同时初始化一个等待队列和一个线程对象; 2. 获取锁:如果锁未被占用,则当前线程获取锁并进入独占模式;如果锁已经被占用,则当前线程加入到等待队列中,并且进入阻塞状态; 3. 释放锁:当前线程释放锁,并且计数器减1,同时唤醒等待队列中的一个线程; 4. 可中断获取锁:如果当前线程在等待锁的过程中被中断,则会抛出`InterruptedException`异常。 总之,`ReentrantLock`是Java中一种功能强大的互斥实现方式,它能够支持可重入特性、公平和非公平锁、可中断获取锁等多种功能。在多线程编程中,使用`ReentrantLock`可以有效地避免线程竞争和死锁等问题。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值