1.常见停止方式

  • 自定义线程,其中含退出标志位,在run中判断它。
  • 使用interrupt()方法中断线程
  • 使用stop方法暴力终止(已经弃用)

2.使用标志位

     class TestThread extends Thread{
         volatile boolean flag = true;
         @Override
         public void run() {
             while (!flag){
                 Log.d(TAG, "running ....");
             }
             Log.d(TAG, "thread " + getId() + " finished !");
             Log.d(TAG, "isAlive " + isAlive());
         }
         public void stopThread(){
             flag = false;
         }
     }
     TestThread testThread;
     void stopThread(){
         Log.d(TAG, "stopThread: isAlive : " + testThread.isAlive());
         Log.d(TAG, "stopThread: isInterrupted : " + testThread.isInterrupted());

         testThread.stopThread();
         Log.d(TAG, "stopThread: isAlive : " + testThread.isAlive());
         Log.d(TAG, "stopThread: isInterrupted : " + testThread.isInterrupted());

     }
  • 调用testThread.stopThread就可以了。
  • 使用场景无限制

3.使用interrupt()方法

3.1示例

   class TestThread extends Thread{
         @Override
         public void run() {
             while (!Thread.currentThread().isInterrupted()){
                 Log.d(TAG, "running .... interrupt = " + this.isInterrupted());
                 try {
                     Thread. * );
                 } catch (InterruptedException e) {
                     e.printStackTrace();
                     Log.d(TAG, "InterruptedException interrupt is reset = " + this.isInterrupted());
                     // Thread.sleep()方法由于中断抛出异常。
                     // Java虚拟机会先将该线程的中断标识位清除,然后抛出InterruptedException,
                     // 因为在发生InterruptedException异常的时候,会清除中断标记
                     // 如果不加处理,那么下一次循环开始的时候,就无法捕获这个异常。
                     // 故在异常处理中,再次设置中断标记位
                     Thread.currentThread().interrupt();
                 }
             }
             Log.d(TAG, "thread " + getId() + " finished !");
             Log.d(TAG, "isAlive " + isAlive());
         }
     }
     TestThread testThread;
     void stopThread(){
         Log.d(TAG, "stopThread: isAlive : " + testThread.isAlive());
         Log.d(TAG, "stopThread: isInterrupted : " + testThread.isInterrupted());

         testThread.interrupt();
         Log.d(TAG, "stopThread: isAlive : " + testThread.isAlive());
         Log.d(TAG, "stopThread: isInterrupted : " + testThread.isInterrupted());

     }

3.1使用场景 

  适合线程处于阻塞状态,如使用了sleep,同步锁的wait,socket中的receiver,accept等方法时。

  当调用阻塞线程的interrupt()方法时,会抛出InterruptException异常。通过代码捕获该异常,然后跳出循环状态,从而让我们有机会结束这个线程的执行。

  调用interrupt方法后线程并不一定会结束, 只有捕获InterruptedException异常之后跳出循环,才能正常结束run方法。

4.Thread.stop()

  已经弃用

  http://www.cnblogs.com/sjjg/p/7625571.html

  

java中的线程(2):如何正确停止线程之3种常见停止方式的更多相关文章

  1. java中的线程(2):如何正确停止线程之2种常见停止方式

    1.常见停止方式 结束run函数,run中含退出标志位. 使用interrupt()方法中断线程 使用stop方法暴力终止(已经弃用) 2.结束run class TestThread extends ...

  2. Java中的线程

    http://hi.baidu.com/ochzqvztdbabcir/item/ab9758f9cfab6a5ac9f337d4 相濡以沫 Java语法总结 - 线程 一 提到线程好像是件很麻烦很复 ...

  3. Java中的线程Thread总结

    首先来看一张图,下面这张图很清晰的说明了线程的状态与Thread中的各个方法之间的关系,很经典的! 在Java中创建线程有两种方法:使用Thread类和使用Runnable接口. 要注意的是Threa ...

  4. 浅谈利用同步机制解决Java中的线程安全问题

    我们知道大多数程序都不会是单线程程序,单线程程序的功能非常有限,我们假设一下所有的程序都是单线程程序,那么会带来怎样的结果呢?假如淘宝是单线程程序,一直都只能一个一个用户去访问,你要在网上买东西还得等 ...

  5. 第9章 Java中的线程池 第10章 Exector框架

    与新建线程池相比线程池的优点 线程池的分类 ThreadPoolExector参数.执行过程.存储方式 阻塞队列 拒绝策略 10.1 Exector框架简介 10.1.1 Executor框架的两级调 ...

  6. Java多线程编程(1)--Java中的线程

    一.程序.进程和线程   程序是一组指令的有序集合,也可以将其通俗地理解为若干行代码.它本身没有任何运行的含义,它只是一个静态的实体,它可能只是一个单纯的文本文件,也有可能是经过编译之后生成的可执行文 ...

  7. 浅析Java中的线程池

    Java中的线程池 几乎所有需要异步或并发执行任务的程序都可以使用线程池,开发过程中合理使用线程池能够带来以下三个好处: 降低资源消耗 提高响应速度 提高线程的可管理性 1. 线程池的实现原理 当我们 ...

  8. Java中的线程到底有哪些安全策略

    摘要:Java中的线程到底有哪些安全策略呢?本文就为你彻底分析下! 本文分享自华为云社区<[高并发]线程安全策略>,作者:冰 河 . 一.不可变对象 不可变对象需要满足的条件 (1)对象创 ...

  9. [译]线程生命周期-理解Java中的线程状态

    线程生命周期-理解Java中的线程状态 在多线程编程环境下,理解线程生命周期和线程状态非常重要. 在上一篇教程中,我们已经学习了如何创建java线程:实现Runnable接口或者成为Thread的子类 ...

随机推荐

  1. Mybatis——Spring整合

    一.引入依赖 Spring的相关jar包 mybatis-3.4.1.jar mybatis-spring-1.3.0.jar mysql-connector-java-5.1.37-bin.jar ...

  2. WCF项目问题1-找不到类型“WCFService.Service1”,它在 ServiceHost 指令中提供为 Service 特性值,或在配置元素 system.serviceModel/serviceHostingEnvironment/serviceActivations 中提供。

    找不到类型“WCFService.Service1”,它在 ServiceHost 指令中提供为 Service 特性值,或在配置元素 system.serviceModel/serviceHosti ...

  3. 彻底清除Window7下的360注册表

    当流氓360遇到强迫症,将注定有一场厮杀... 今天装了个虚拟机,其中win7系统是在网上随便下载了一个,是非纯净版的,自带了360在内的好多软件,其他软件都轻松删掉,但查看注册表时发现竟然有360残 ...

  4. ibatis和hibernate

    ibatis:sql需要自己写hibernate:sql自动生成上面是最大的区别,下面是一些细节.选择Hibernate还是iBATIS都有它的道理:Hibernate的特点:Hibernate功能强 ...

  5. 实践作业3:白盒测试----小组分工讨论DAY2

    白盒测试需要通过检查软件内部的逻辑结构,对软件中的逻辑路径进行覆盖测试;在程序不同地方设立检查点,检查程序的状态,以确定实际运行状态与预期状态是否一致.我们小组在下课时候,在东九教学楼教师休息室进行了 ...

  6. Python基础-5

    目录 time &datetime模块 random os sys shutil json & picle shelve xml处理 yaml处理 hashlib re正则表达式 模块 ...

  7. linux内存监控 free

    free 命令详解: 执行命令后总共四行. 第一行: 列头 第二行: total 内存总数: 32881776 used 已经使用的内存数: 8324796 free 空闲的内存数: 24556980 ...

  8. 编写高质量代码改善C#程序的157个建议——建议42:使用泛型参数兼容泛型接口的不可变性

    建议42:使用泛型参数兼容泛型接口的不可变性 让返回值类型返回比声明的类型派生程度更大的类型,就是“协变”.如: public Employee GetAEmployee(string name) { ...

  9. 20169219 SQL注入实验报告

    实验介绍 SQL注入技术是利用web应用程序和数据库服务器之间的接口来篡改网站内容的攻击技术.通过把SQL命令插入到Web表单提交框.输入域名框或页面请求框中,最终欺骗服务器执行恶意的SQL命令. 在 ...

  10. Android之AlterDialog介绍

    效果: 1.简单对话框 AlertDialog.Builder builder=new AlertDialog.Builder(AlterDialogActivity.this); builder . ...