继续浏览精彩内容
慕课网APP
程序员的梦工厂
打开
继续
感谢您的支持,我会继续努力的
赞赏金额会直接到老师账户
将二维码发送给自己后长按识别
微信支付
支付宝支付

LockSupport线程睡眠

慕村9548890
关注TA
已关注
手记 1296
粉丝 227
获赞 991

LockSupport通常使用park()和unpark()方法以及其他带有超时控制的变体方法,控制线程的调度。但park的睡眠状态会在多种情况下被唤醒,例如:unpark()调用,线程被中断,超时等因素,所以park()需要在循环中调用,被唤醒后需要重新检查执行条件,不满足条件则需要重新park(),可以说它是一种优化的忙等待(也就是自旋),例如:。

while (!canProceed()) {
    LockSupport.park(this); 
}

做个简单的实验

public static void main(String[] args) throws IOException, InterruptedException {
        Thread[] ts = new Thread[5];        for (int i = 0; i < ts.length; i++) {
            ts[i] = new Thread(new Runnable() {                @Override
                public void run() {
                    LockSupport.park();
                    System.out.println(Thread.currentThread().getName());
                }
            });
            ts[i].start();
        }
        System.out.println("所有的线程给我睡眠5秒");        long start = System.currentTimeMillis();
        TimeUnit.SECONDS.sleep(5);
        System.out.println("睡眠结束,睡眠时间" + (System.currentTimeMillis() - start));        for (Thread t : ts) {
            LockSupport.unpark(t);
        }
        System.in.read();
    }

打印结果:

webp


以上就是LockSupport的简单应用。不过,需要记住LockSupport.park()会被中断唤醒,但不会产生中断异常。



作者:关捷
链接:https://www.jianshu.com/p/849dc1399159


打开App,阅读手记
0人推荐
发表评论
随时随地看视频慕课网APP