java多线程顺序执行并顺序输出ABC问题


1.有A、B、C、D四个线程,A线程输出A, B线程输出B, C线程输出C,D线程输出D,要求, 同时启动四个线程, 按顺序输出ABCD;

本题主要通过join方法来实现顺序输出ABCD。

代码如下:

package thread;

/**
 * @author Beauxie
 */
public class TestThread1 {

	public static void main(String[] args) {

		// 线程A
		final Thread a = new Thread(new Runnable() {

			@Override
			public void run() {
				System.out.println("A");

			}
		});

		// 线程B
		final Thread b = new Thread(new Runnable() {
			@Override
			public void run() {
				try {
					// 执行b线程之前,加入a线程,让a线程执行
					a.join();
				} catch (InterruptedException e) {
					e.printStackTrace();
				}
				System.out.println("B");

			}
		});

		// 线程C
		final Thread c = new Thread(new Runnable() {

			@Override
			public void run() {
				try {
					// 执行c线程之前,加入b线程,让b线程执行
					b.join();
				} catch (InterruptedException e) {
					e.printStackTrace();
				}
				System.out.println("C");

			}
		});

		// 线程D
		Thread d = new Thread(new Runnable() {

			@Override
			public void run() {
				try {
					// 执行d线程之前,加入c线程,让c线程执行
					c.join();
				} catch (InterruptedException e) {
					e.printStackTrace();
				}
				System.out.println("D");
			}
		});

		// 启动四个线程
		a.start();
		b.start();
		c.start();
		d.start();

	}

}
运行结果:


2.有A,B,C三个线程, A线程输出A, B线程输出B, C线程输出C  要求, 同时启动三个线程, 按顺序输出ABC, 循环10次;

代码如下:

package thread;

import java.util.concurrent.locks.Lock;
import java.util.concurrent.locks.ReentrantLock;

/**
 * @author Beauxie
 */
public class TestThresd2 {

	// //通过JDK5中的锁来保证线程的访问的互斥
	private static Lock lock = new ReentrantLock();

	private static int state = 0;// 用state来判断轮到谁执行
	
	private static final int RUN_NUMBER=100;//表示循环的次数

	//A线程
	static class ThreadA extends Thread {

		@Override
		public void run() {
			for (int i = 0; i < RUN_NUMBER;) {
 				lock.lock();//获取锁定
				if (state % 3 == 0) {
					System.out.println("第"+(i+1)+"次:");
					System.out.println("A");
					state++;
					i++;
				}
 				lock.unlock();//释放锁定,不释放锁定,会被该线程一直保持
			}
		}
	}
	//B线程
	static class ThreadB extends Thread {
		
		@Override
		public void run() {
			for (int i = 0; i < RUN_NUMBER;) {
 				lock.lock();
				if (state % 3 ==1) {
					System.out.println("B");
					state++;
					i++;
				}
 				lock.unlock();
			}
		}
	}
	//C线程
	static class ThreadC extends Thread {
		
		@Override
		public void run() {
			for (int i = 0; i < RUN_NUMBER;) {
 				lock.lock();
				if (state % 3 == 2) {
					System.out.println("C");
					state++;
					i++;
				}
 				lock.unlock();
			}
		}
	}
	public static void main (String[] args){
		new ThreadA().start();
		new ThreadB().start();
		new ThreadC().start();
	}

}
在这里我将循环次数改成100次,运行结果:

本题参考自:http://love3400wind.blog.163.com/blog/static/796308012013117102941831/


如果各位有更好的思路,麻烦请告诉我,谢谢!


  • 8
    点赞
  • 27
    收藏
    觉得还不错? 一键收藏
  • 3
    评论
可以使用线程同步的方法来实现三个线程顺序执行,比如使用信号量或互斥锁。 具体实现方法如下: 1. 创建三个线程,分别执行任务 A、B、C。 2. 使用信号量或互斥锁来同步三个线程执行。在任务 A 执行完后,释放信号量或解锁互斥锁,使得任务 B 可以执行;在任务 B 执行完后,同样释放信号量或解锁互斥锁,使得任务 C 可以执行。 3. 在主线程中等待三个子线程全部执行完毕,然后结束程序。 下面是一个简单的示例代码: ```c #include <stdio.h> #include <pthread.h> #include <semaphore.h> sem_t sem1, sem2; void *threadA(void *arg) { printf("Thread A\n"); sem_post(&sem1); // 释放信号量 sem1 pthread_exit(NULL); } void *threadB(void *arg) { sem_wait(&sem1); // 等待信号量 sem1 printf("Thread B\n"); sem_post(&sem2); // 释放信号量 sem2 pthread_exit(NULL); } void *threadC(void *arg) { sem_wait(&sem2); // 等待信号量 sem2 printf("Thread C\n"); pthread_exit(NULL); } int main() { sem_init(&sem1, 0, 0); // 初始化信号量 sem1 sem_init(&sem2, 0, 0); // 初始化信号量 sem2 pthread_t tid1, tid2, tid3; pthread_create(&tid1, NULL, threadA, NULL); pthread_create(&tid2, NULL, threadB, NULL); pthread_create(&tid3, NULL, threadC, NULL); pthread_join(tid1, NULL); pthread_join(tid2, NULL); pthread_join(tid3, NULL); sem_destroy(&sem1); // 销毁信号量 sem1 sem_destroy(&sem2); // 销毁信号量 sem2 return 0; } ``` 在上面的示例代码中,信号量 sem1 和 sem2 分别用来同步任务 A、B 和任务 B、C 的执行线程 A 执行完后释放信号量 sem1,线程 B 等待信号量 sem1,线程 B 执行完后释放信号量 sem2,线程 C 等待信号量 sem2。最后,主线程等待三个子线程执行完毕后才结束程序。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值