三个线程abc并发运行,b,c需要a线程的数据怎么实现(semaphore.acquire()方法和permit标记)
Posted scar1et
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了三个线程abc并发运行,b,c需要a线程的数据怎么实现(semaphore.acquire()方法和permit标记)相关的知识,希望对你有一定的参考价值。
public class ThreadCommunication { /** * 三个线程a、b、c并发运行,b,c需要a线程的数据怎么实现 * * 根据问题的描述,通过三个线程,ThreadA ThreadB ThreadC * ThreadA用于初始化数据num,只有num初始化完成之后再让ThreadB和ThreadC获取到初始化的变量num。 * * * 分析过程如下: * 考虑到线程的不确定性,因此我们不能确保ThreadA就一定先于ThreadB和ThreadC前执行,就算 * ThreadA先执行了,我们也无法保证ThreadA什么时候才能将变量num初始化完成。因此我们必须让 * ThreadB和ThreadC去等待ThreadA完成任务后发出的消息 * * 解决两个问题: * 1:让ThreadB和ThreadC先执行完 * 2:ThreadA执行完之后给ThreadB和ThreadC发送消息 */ /** * 两种解决方案 * 1、使用纯Java API的Semaphore类来控制线程的等待和释放 * 2、使用android提供的消息机制 */ //定义一个变量作为数据 private static int num; public static void main(String[] args) { Thread threadA = new Thread(new Runnable() { @Override public void run() { try { //模拟耗时操作之后初始化变量num Thread.sleep(1000); num=1; } catch (InterruptedException e) { e.printStackTrace(); } } }); Thread threadB = new Thread(new Runnable() { @Override public void run() { System.out.println(Thread.currentThread().getName()+"获取到num的值为:"+num); } }); Thread threadC = new Thread(new Runnable() { @Override public void run() { System.out.println(Thread.currentThread().getName()+"获取到num的值为:"+num); } }); //同时开启三个线程 threadA.start(); threadB.start(); threadC.start(); } }
运行结果:
Thread-2获取到num的值为:0
Thread-1获取到num的值为:0
解决方案1:
public class ThreadCommunication { /** * 三个线程a、b、c并发运行,b,c需要a线程的数据怎么实现 public class ThreadCommunication { //定义一个变量作为数据 private static int num; /** * 定义一个信号量,该类内部维持了多个线程锁,可以阻塞多个线程,释放多个线程 * 线程的阻塞是和释放是通过permit概念来实现的 * 线程通过semaphore.acquire()方法获取permit,如果当前线程有permit则分配给该线程 * 如果没有则阻塞该线程直到semaphore * 调用release()方法释放permit * 构造函数中参数:permit(允许)个数; */ private static Semaphore semaphore = new Semaphore(0); public static void main(String[] args) { Thread threadA = new Thread(new Runnable() { @Override public void run() { try { //模拟耗时操作之后初始化变量num Thread.sleep(1000); num = 1; //初始化参数后释放两个permit semaphore.release(2); } catch (InterruptedException e) { e.printStackTrace(); } } }); Thread threadB = new Thread(new Runnable() { @Override public void run() { try { //获取permit,如果semaphore没有可用的permit则等待,如果有则消耗一个 semaphore.acquire(); } catch (InterruptedException e) { e.printStackTrace(); } System.out.println(Thread.currentThread().getName()+"获取到的num的值为:"+num); } }); Thread threadC = new Thread(new Runnable() { @Override public void run() { try { //获取permit,如果semaphore没有可用的permit则等待,如果有则消耗一个 semaphore.acquire(); } catch (InterruptedException e) { e.printStackTrace(); } System.out.println(Thread.currentThread().getName()+"获取到的num的值为:"+num); } }); //同时开启三个线程 threadA.start(); threadB.start(); threadC.start(); } }
运行结果:
Thread-1获取到的num的值为:1
Thread-2获取到的num的值为:1
以上是关于三个线程abc并发运行,b,c需要a线程的数据怎么实现(semaphore.acquire()方法和permit标记)的主要内容,如果未能解决你的问题,请参考以下文章