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(); }
打印结果:
以上就是LockSupport的简单应用。不过,需要记住LockSupport.park()会被中断唤醒,但不会产生中断异常。
作者:关捷
链接:https://www.jianshu.com/p/849dc1399159
点击查看更多内容
为 TA 点赞
评论
共同学习,写下你的评论
评论加载中...
作者其他优质文章
正在加载中
感谢您的支持,我会继续努力的~
扫码打赏,你说多少就多少
赞赏金额会直接到老师账户
支付方式
打开微信扫一扫,即可进行扫码打赏哦