多线程面试题(一):现在有T1、T2、T3三个线程,你怎样保证T2在T1执行完后执行,T3在T2执行完后执行?

问:现在有T1、T2、T3三个线程,你怎样保证T2在T1执行完后执行,T3在T2执行完后执行?

答:要保证T1、T2、T3三个线程顺序执行,可以利用Thread类的join方法。

问:join方法的作用?

答: Thread类中的join方法的主要作用就是同步,它可以使得线程之间的并行执行变为串行执行。当我们调用某个线程的这个方法时,这个方法会挂起调用线程,直到被调用线程结束执行,调用线程才会继续执行。

问:join方法传参和不传参的区别?

答:join方法中如果传入参数,则表示这样的意思:如果A线程中掉用B线程的join(10),则表示A线程会等待B线程执行10毫秒,10毫秒过后,A、B线程并行执行。需要注意的是,jdk规定,join(0)的意思不是A线程等待B线程0秒,而是A线程等待B线程无限时间,直到B线程执行完毕,即join(0)等价于join()。

代码如下:

/*
 * 本测试程序主要是测试join方法的传参与不传参的区别
 * */
package com.threadDemo;

public class JoinTest {

	public static void main(String[] args) throws InterruptedException {
		// TODO Auto-generated method stub
	   ThreadJoinTest t1 = new ThreadJoinTest("夏天");
       ThreadJoinTest t2 = new ThreadJoinTest("秋天
在Java中,为了实现这样的线程同步,可以使用`synchronized`, `wait()`, 和 `notifyAll()` 等并发工具。我们可以创建一个包含共享资源的对象,并利用 `volatile` 关键字防止数据竞争。下面是一个简单的例子: ```java public class ThreadTask { private volatile int result; private final Object lock = new Object(); public void startThreads(int t2Result, int t3Result) { Thread t1 = new Thread(() -> { synchronized (lock) { try { result = Math.max(t2Result, t3Result); System.out.println("T1 got results, result is " + result); // Notify T2 and T3 that result is available lock.notifyAll(); } catch (InterruptedException e) { e.printStackTrace(); } } }); Thread t2 = new Thread(() -> { while (!Thread.currentThread().equals(t1)) { try { lock.wait(); } catch (InterruptedException e) { e.printStackTrace(); } } // Simulate a task with random delay for result try { Thread.sleep(1000); } catch (InterruptedException e) { e.printStackTrace(); } result = t2Result; // Set your own result }); Thread t3 = new Thread(() -> { while (!Thread.currentThread().equals(t1)) { try { lock.wait(); } catch (InterruptedException e) { e.printStackTrace(); } } // Similar to T2, simulate a task try { Thread.sleep(500); } catch (InterruptedException e) { e.printStackTrace(); } result = t3Result; }); t1.start(); t2.start(); t3.start(); // Wait for all threads to finish try { t1.join(); t2.join(); t3.join(); } catch (InterruptedException e) { e.printStackTrace(); } } public static void main(String[] args) { ThreadTask task = new ThreadTask(); task.startThreads(10, 20); // Replace with actual values or generate them dynamically } } ``` 在这个例子中,`startThreads`方法启动了三个线程`t1`, `t2`, 和 `t3`。`t1`负责获取并存储结果,然后唤醒等待的`t2`和`t3`。`t2`和`t3`分别模拟延迟任务并在得到通知后设置自己的结果。主线程会等待所有线程完成。
评论 4
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值