方法一:
@Override
public void run(){
for(int i = 0; i < 100; i++){
System.out.println(this.getname()+":"+i);
try{
Thread.sleep(1000);
}catch(InterruptedException e){
System.out.println("异常结束!");
return; //在异常中直接返回,从而打断线程
}
}
}
方法二(Java推荐的方法):
//通过自定义一个FlagThread中断线程的方法,调用直接中断
public void FlagThread extends Thread{
//设置中断标志
private boolean isInterrupted = false;
//中断线程方法
public void stopCurrentThread(){
this.isInterrupted = true; //中断标志
super.interrupt(); //调用系统中断,发起异常
}
@Override
public void run(){
while(!isInterrupted){
try{
for(int i = 0; i < 100; i++){
System.out.println(this.getname()+":"+i);
Thread.sleep(1000);
}
}catch(InterruptedException e){
//中断抛出异常,通过标记方式结束线程
}
}
System.out.println("异常结束!");
}
}
方法三
正常方式中断线程,要求不能在循环中调用sleep()方法
关于IO读写的线程停止
理论上无法停止,只能中断IO流,抛出异常后再处理。最好的建议就是将大数据的 IO 读写操作放在循环中进行,这样可以在每次循环中都有线程停止的时机,这也将问题转化成了如何停止正在运行中的线程的问题了。
Java之多线程interrupt中断线程的三种方法
发表于:2017-08-08
作者:网络转载
来源:
 相关文章
前端到底是“技术深度”重要还是“技... 悟透一个小窍门,你就能举一反三掌握... 聊聊架构设计流程:设计备选方案 Java中的并发编程模型及其应对策略 掌握Java并发编程,避免无处不在的竞态条件 2024年,五个Java开发者应该关注的编程趋势- 周排行
- 月排行
-   Python 模块 asyncio-异步IO,事件循环和并发
-   13个Python web框架比较
-   微服务架构:构建高灵活性的分布式系统
-   我们一起聊聊如何提高API性能的综合策略
-   构建成功的开源项目的重要建议
-   Prepack—JavaScript代码优化工具
-   聊聊并发编程两原则,你明白了吗?
-   我们一起聊聊如何提高API性能的综合策略
-   工作中最常见的6种OOM(内存溢出)问...
-   看大牛是如何阅读JDK源码,涨涨见识
-   程序员开发利器?在线工具集锦
-   工作中有没有做过性能调优?一问这个...
-   Java线程池为什么先入队列再增加线程数?
-   DDD领域驱动工程落地实战