关于java.util.concurrent您不知道的5件事,第2部分 - 编程入门网
System.out.println("PING!");
}
};
ses.scheduleAtFixedRate(pinger, 5, 5, TimeUnit.SECONDS);
}
}
这项功能怎么样?不用过于担心线程,不用过于担心用户希望取消心跳时会发生什么,也不 用明确地将线程标记为前台或后台;只需将所有的计划细节留给 ScheduledExecutorService。 顺便说一下,如果用户希望取消心跳,scheduleAtFixedRate 调用将返回一个 ScheduledFuture 实例,它不仅封装了结果(如果有),还拥有一个 cancel 方法来关闭计划 的操作。 5. Timeout 方法 为阻塞操作设置一个具体的超时值(以避免死锁)的能力是 java.util.concurrent 库相比 起早期并发特性的一大进步,比如监控锁定。 这些方法几乎总是包含一个 int/TimeUnit 对,指示这些方法应该等待多长时间才释放控制 权并将其返回给程序。它需要开发人员执行更多工作 — 如果没有获取锁,您将如何重新获取 ? — 但结果几乎总是正确的:更少的死锁和更加适合生产的代码。 结束语 java.util.concurrent 包还包含了其他许多好用的实用程序,它们很好地扩展到了 Collections 之外,尤其是在 .locks 和 .atomic 包中。深入研究,您还将发现一些有用的控 制结构,比如 CyclicBarrier 等。 与 Java 平台的许多其他方面一样,您无需费劲地查找可能非常有用的基础架构代码。在编 写多线程代码时,请记住本文讨论的实用程序和 上一篇文章 中讨论的实用程序。 下一次,我们将进入一个新的主题:关于 Jars 您不知道的 5 件事。 原文地址:http://www.ibm.com/developerworks/cn/java/j-5things5.html |
凌众科技专业提供服务器租用、服务器托管、企业邮局、虚拟主机等服务,公司网站:http://www.lingzhong.cn 为了给广大客户了解更多的技术信息,本技术文章收集来源于网络,凌众科技尊重文章作者的版权,如果有涉及你的版权有必要删除你的文章,请和我们联系。以上信息与文章正文是不可分割的一部分,如果您要转载本文章,请保留以上信息,谢谢! |