join()介绍及三个线程顺序输出实现

一、join介绍

  Thead.join()函数在使用后,会挂起调用线程,直到被调用线程结束执行,调用线程才会继续执行。源码中调用join后,方法会一直检测要join()的线程是否存活(isAlive()方法),直到线程执行完成后,调用线程的this.notifyAll()方法,才会回到刚刚挂起的主程序。基本操作如下:

public class Worker extends Thread {

    // 工作者名
    private String name;
    // 工作时间
    private long time;

    public Worker(String name, long time) {
        this.name = name;
        this.time = time;
    }

    @Override
    public void run() {
        // TODO 自动生成的方法存根
        try {        
            System.out.println(name + "开始工作");
     Thread.sleep(time);   
            System.out.println(name + "工作完成,耗费时间=" + time);
        } catch (InterruptedException e) {
            // TODO 自动生成的 catch 块
            e.printStackTrace();
        }
    }

}

public static void main(String[] args) throws InterruptedException {
        // TODO Auto-generated method stub
        Worker worker0 = new Worker("worker0", (long) (Math.random() * 1000));
        Worker worker1 = new Worker("worker1", (long) (Math.random() * 1000 + 1000));
        Worker worker2 = new Worker("worker2", (long) (Math.random() * 1000 + 2000));
        
        worker1.start();
        worker0.start();

        worker1.join();
        worker0.join();
        System.out.println("准备工作就绪");

        worker2.start();
    }

  结果如下:

 

二、join方式代码实现

  有了上面的介绍很容易想到,三个线程顺序输出,让他们依次join(),按顺序等待执行就好了,代码如下:

public static void main(String[] args) {
        final Thread t1 = new Thread(new Runnable() {
            public void run() {
                System.out.println(Thread.currentThread().getName() + " run 1");
            }
        }, "T1");
        final Thread t2 = new Thread(new Runnable() {
            public void run() {

                try {
                    t1.join();
                    System.out.println(Thread.currentThread().getName() + " run 2");
                } catch (InterruptedException e) {
                    e.printStackTrace();
                }
            }
        }, "T2");
        final Thread t3 = new Thread(new Runnable() {
            public void run() {
                try {
                    t2.join();
                    System.out.println(Thread.currentThread().getName() + " run 3");
                } catch (InterruptedException e) {
                    e.printStackTrace();
                }
            }
        }, "T3");

        t1.start();
        t2.start();
        t3.start();
        
        //方法二
        // ExecutorService executor = Executors.newSingleThreadExecutor();
        // executor.submit(t1);
        // executor.submit(t2);
        // executor.submit(t3);
        // executor.shutdown();
    }

  效果如图:

 

三、既然是多线程,自然也可以用加锁的方式实现,直接上代码:

package com.concurrency;

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

public class ThreeTheadPrintByOrder2_Lock {

    public static void main(String[] args) {
        new ThreadA().start();
        new ThreadB().start();
        new ThreadC().start();
    }

    private static Lock lock = new ReentrantLock();
    private static int state = 0;

    static class ThreadA extends Thread {
        @Override
        public void run() {
            for (int i = 0; i < 10;) {
                lock.lock();
                if (state % 3 == 0) {
                    System.out.println(Thread.currentThread().getName() + " A");
                    state++;
                    i++;
                }
                lock.unlock();
            }
        }
    }

    static class ThreadB extends Thread {
        @Override
        public void run() {
            for (int i = 0; i < 10;) {
                lock.lock();
                if (state % 3 == 1) {
                    System.out.println(Thread.currentThread().getName() + " B");
                    state++;
                    i++;
                }
                lock.unlock();
            }
        }
    }

    static class ThreadC extends Thread {
        @Override
        public void run() {
            for (int i = 0; i < 10;) {
                lock.lock();
                if (state % 3 == 2) {
                    System.out.println(Thread.currentThread().getName() + " C");
                    state++;
                    i++;
                }
                lock.unlock();
            }
        }
    }

}

  效果如下:

 

  

转载于:https://www.cnblogs.com/lyInfo/p/9130094.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
可以使用线程同步的方法来实现三个线程的顺序执行,比如使用信号量或互斥锁。 具体实现方法如下: 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。最后,主线程等待三个子线程执行完毕后才结束程序。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值