线程调度

Thread.Join()

Thread类中的Join方法可以是线程间的并行执行变为串行执行。join方法放弃当前线程的执行,执行join对应的线程。

示例

程序在main线程中调用t1线程的join方法,则main线程放弃cpu控制权,并返回t1线程继续执行直到线程t1执行完毕
所以结果是t1线程执行完后,才到主线程执行,相当于在main线程中同步t1线程,t1执行完了,main线程才有执行的机会,继续执行t2线程。其中join方法int参数为t1线程执行时间,即被中断的线程等待t1执行n毫秒后再执行。

public class ThreadJoinTest {
    public static void main(String[] args) throws Exception{
        ThreadJoinDemo t1 = new ThreadJoinDemo("小明");
        ThreadJoinDemo t2 = new ThreadJoinDemo("小红");
        t1.start();
        t1.join(10);
        t2.start();
    }
}

class ThreadJoinDemo extends Thread{
    public ThreadJoinDemo(String name){
        super(name);
    }

    @Override
    public void run(){
        for(int i=0;i<100;i++){
            System.out.println(this.getName()+":"+i);
        }
    }
}

原理

当前线程A调用线程B的join方法时相当于调用了wait方法。当B线程执行完或达到等待时间后B线程会自动调用吱声的notifyAll方法唤醒A线程。

源码

public final synchronized void join(long millis)
throws InterruptedException {
    long base = System.currentTimeMillis();
    long now = 0;

    if (millis < 0) {
        throw new IllegalArgumentException("timeout value is negative");
    }

    if (millis == 0) {
        while (isAlive()) {
            wait(0);
        }
    } else {
        while (isAlive()) {
            long delay = millis - now;
            if (delay <= 0) {
                break;
            }
            wait(delay);
            now = System.currentTimeMillis() - base;
        }
    }
}
  • 2
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Windows线程调度是操作系统对线程进行管理和分配CPU时间的过程。Windows采用抢占式调度策略,即当一个线程的时间片用完或者发生某些事件时,操作系统会中断当前线程的执行并切换到其他线程的执行。引用中提到了一些引发线程调度的事件,包括IO操作完成、信号量或事件提前结束、前台进程中的线程完成了一个等待动作、因窗口活动而唤醒窗口线程以及线程处于就绪状态超过一定时间还未运行等。当这些事件发生时,操作系统会重新选择一个合适的线程来执行,并且根据线程的优先级和时间配额来确定线程调度顺序。引用中提到,当调用CreateProcess或者CreateThread时,系统会创建线程内核对象,并将挂起计数初始化为1,这样线程就不会被立即调度执行,而是在线程准备好之后再开始执行,以避免在初始化过程中发生错误。 为了提升调度策略的公平性和改善整体吞吐量以及响应时间,Windows还采用了一些方法。引用中提到了提升线程优先级和分配较大时间配额的方法。当某些条件满足时,Windows会提升线程的优先级,例如IO操作完成、信号量或事件提前结束、前台进程中的线程完成了一个等待动作、因窗口活动而唤醒窗口线程以及线程处于就绪状态超过一定时间还未运行(即"饥饿"现象)。通过提升线程优先级和分配较大时间配额,Windows可以提高线程调度优先级,确保重要的任务能够及时得到执行,从而改善整体系统的性能和响应能力。 综上所述,Windows线程调度是操作系统对线程进行管理和分配CPU时间的过程。Windows采用抢占式调度策略,根据线程的优先级和时间配额来决定线程调度顺序。当发生特定事件或满足特定条件时,Windows会中断当前线程的执行并切换到其他线程的执行,以提高调度策略的公平性和系统的性能。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值