多线程的学习:day6 线程的强制运行

文章讲述了Java中如何使用Join()方法来确保子线程A在执行过程中,主线程B被阻塞等待,直到A线程执行完毕。通过Vip类实现Runnable接口并结合TestJoin类的示例,演示了join方法在控制线程执行顺序中的作用。
摘要由CSDN通过智能技术生成

线程的强制运行:举例说明就是A线程执行了Join()方法之后,B线程不能够执行,要A线程执行完之后B线程才能执行,也就是说A线程执行的过程中,其他线程阻塞,可以理解为插队

6.1 创建一个类实现Runnable接口,并在run方法里面写入代表子线程(也就是上述解释的A线程)的代码逻辑

class Vip implements Runnable{
    @Override
    public void run() {
        for (int i = 0; i < 100; i++) {
            System.out.println("线程vip来了" + i);
        }
    }
}

6.2 创建一个main类(代表上述的B线程),引入那个实现Runnable接口的类的对象,启动这个类的线程,然后写一段代表main类的执行代码逻辑,规定当某个条件时run()方法开始执行(A线程)

public class TestJoin  {
    public static void main(String[] args) throws InterruptedException {
        //启动线程
        Vip xieyuhui = new Vip();
        new Thread(xieyuhui).start();

        //下面主线程
        for (int i = 0; i < 1000; i++) {
            if (i == 200){
                new Thread(xieyuhui).join();  //插队,此时运行run()方法的逻辑
            }
            System.out.println("main" + i);
        }

    }
}

结果分析

可以看到,当i = 200就已经有子线程执行,这是CPU调度问题,但当之后就一定要确保子线程比主线程要快速执行完

如果缺少join方法,就不可能保证子线程一定比主线程要先执行完

下面是简单测试join方法的完整代码

//Join合并线程,待线程执行完成后,再执行其他线程,其他线程阻塞,可以想象为插队
public class TestJoin  {
    public static void main(String[] args) throws InterruptedException {
        //启动线程
        Vip xieyuhui = new Vip();
        new Thread(xieyuhui).start();

        //下面主线程
        for (int i = 0; i < 1000; i++) {
            if (i == 200){
                new Thread(xieyuhui).join();  //插队,此时运行run()方法的逻辑
            }
            System.out.println("main" + i);
        }

    }
}
class Vip implements Runnable{
    @Override
    public void run() {
        for (int i = 0; i < 100; i++) {
            System.out.println("线程vip来了" + i);
        }
    }
}

  • 7
    点赞
  • 8
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值