- 1、本文档共10页,可阅读全部内容。
- 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 5、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 6、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 7、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 8、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
interrupt()和线程终止方式
中断线程
线程的 thread.interrupt()方法是中断线程,将会设置该线程的中断状态位,即设置为 true ,中断的结果线程是死亡、
还是等待新的任务或是继续运行至下一步,就取决于这个程序本身。线程会不时地检测这个中断标示位,以判断线程是否应
该被中断(中断标示值是否为 true )。它并不像stop 方法那样会中断一个正在运行的线程。
判断线程是否被中断
判断某个线程是否已被发送过中断请求,请使用 Thread.currentThread().isInterrupted()方法(因为它将线程中断标
示位设置为 true 后,不会立刻清除中断标示位,即不会将中断标设置为 false ),而不要使用thread.interrupted() (该方法
调用后会将中断标示位清除,即重新设置为 false )方法来判断,下面是线程在循环中时的中断方式:
while(!Thread.currentThread().isInterrupted() more work to do){
do more work
}
如何中断线程
如果一个线程处于了阻塞状态(如线程调用了 thread.sleep、thread.join、thread.wait、1.5 中的condition.await、
以及可中断的通道上的 I/O 操作方法后可进入阻塞状态),则在线程在检查中断标示时如果发现中断标示为 true ,则会在
这些阻塞方法(sleep、join 、wait、1.5 中的condition.await 及可中断的通道上的 I/O 操作方法)调用处抛出
InterruptedException 异常,并且在抛出异常后立即将线程的中断标示位清除,即重新设置为 false。抛出异常是为了线程
从阻塞状态醒过来,并在结束线程前让程序员有足够的时间来处理中断请求。
注,synchronized 在获锁的过程中是不能被中断的,意思是说如果产生了死锁,则不可能被中断(请参考后面的测试
例子)。与 synchronized 功能相似的 reentrantLock.lock()方法也是一样,它也不可中断的,即如果发生死锁,那么
reentrantLock.lock()方法无法终止,如果调用时被阻塞,则它一直阻塞到它获取到锁为止。但是如果调用带超时的 tryLock
方法 reentrantLock.tryLock(long timeout, TimeUnit unit) ,那么如果线程在等待时被中断,将抛出一个
InterruptedException 异常,这是一个非常有用的特性,因为它允许程序打破死锁。你也可以调用
reentrantLock.lockInterruptibly()方法,它就相当于一个超时设为无限的 tryLock 方法。
没有任何语言方面的需求一个被中断的线程应该终止。中断一个线程只是为了引起该线程的注意,被中断线程可以决定
如何应对中断。某些线程非常重要,以至于它们应该不理会中断,而是在处理完抛出的异常之后继续执行,但是更普遍的情
况是,一个线程将把中断看作一个终止请求,这种线程的 run 方法遵循如下形式:
public void run() {
try {
...
/*
* 不管循环里是否调用过线程阻塞的方法如 sleep、join 、wait ,这里还是需要加上
* !Thread.currentThread().isInterrupted()条件,虽然抛出异常后退出了循环,显
* 得用阻塞的情况下是多余的,但如果调用了阻塞方法但没有阻塞时,这样会更安全、更及时。
*/
1 / 10
while (!Thread.currentThread().isInterrupted() more work to do) {
do more work
}
} catch (InterruptedException e) {
//线程在 wait 或 sleep 期间被中断了
} finally {
//线程结束前做一些清理工作
}
}
上面是
您可能关注的文档
- FLS 测量及仪表_20141015.pdf
- form手电筒lov与窗口查询创建.pdf
- FORTRAN90第6篇子程序.ppt
- Fortran程序设计(第2章-简单程序设计).ppt
- foxmail 7 的安装及使用.ppt
- FPGA_ASIC-基于FPGA的OQPSK解调器的设计及实现.pdf
- FPGA原理和应用2012_01.ppt
- FPS游戏显卡与鼠标设置(仅供参考).doc
- FRP加固钢结构研究进展.pdf
- FTP 安装及用户权限设置.ppt
- jian lake blue bay建造并保存原始千历史沙丘球场简述hole by descriptions.pdf
- 仲裁法条18 great wall offor foreign arbitration institution外国机构.pdf
- 文本文稿介绍tecsis gmbh carl-legien str 40 de247.pdf
- 专着青霉素penicillin g钠注射.pdf
- m地理上层中等测试级别1geography paper 1 hlsl spanish.pdf
- 营养支持高蛋白质能源产品hepintake.pdf
- 文稿参数技术read me first.pdf
- atheros ar6000主持人sdiocf驱动程序课件.pdf
- 分析说明table of content installation 2 arma2-manualARMA2手动.pdf
- 业务运营上报内容汇.pdf
文档评论(0)