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. Linux、Windows中的相对路径和绝对路径

    获取系统的分隔符的方式:System.getProperty("file.separator")   Windows为 \   Linux为/ Windows绝对路径: 以盘符开始 ...

  2. .NET将服务器文件导出

    导出文件:                string filePath = Server.UrlDecode(filePath);                if (File.Exists(fi ...

  3. M(必备),R(需求),C(条件),O(可选)

    M:must 必备 R:request 需求 C:condition 条件 O:option 可选 AFL:application file locator 应用文件定位器 PKI:公钥索引 IPK: ...

  4. 【Azure Active Directory】单一登录 (SAML 协议)

    Azure Active Directory 支持 SAML 2.0 Web 浏览器单一登录 (SSO) 配置文件. 若要请求 Azure Active Directory 对用户进行身份验证时,云服 ...

  5. 图的遍历——BFS

    原创 裸一篇图的BFS遍历,直接来图: 简单介绍一下BFS遍历的过程: 以上图为例子,从0开始遍历,访问0,按大小顺序访问与0相邻的所有顶点,即先访问1,再访问2: 至此顶点0已经没有作用了,因为其本 ...

  6. MongoDB整理笔记の体系架构

    MongoDB 是一个可移植的数据库,它在流行的每一个平台上都可以使用,即所谓的跨平台特性. 一个运行着的MongoDB 数据库就可以看成是一个MongoDB Server,该Server 由实例和数 ...

  7. 浅谈delphi创建Windows服务程序与窗体实现交互

    我想实现的功能是创建一个服务程序,然后在服务Start时动态创建一个窗体Form,然后把Form缩小时变成TrayIcon放在Windows托盘上. 我在服务程序的OnStart事件中写到 Start ...

  8. mysql数据库学习小结

    数据库的学习可以从以下几个层次了解掌握,这样思路清晰后后面不管怎么变化都可以随时应变: 1.mysql基础知识 2.操作数据库的方法,增 删 改 查 3.jdbc连接数据库,工作原理 难点重点,如:P ...

  9. SurfaceView和SurfaceHolder的基本用法

    仅做记录使用,新手也可以来看看,怎么得到一个surfaceholder. 1.在xml文件中增加一个surfaceView控件. <SurfaceView android:layout_widt ...

  10. c# 锁的使用

    1 互斥锁lock(基于Monitor实现) 定义: private static readonly object Lock = new object(); 使用: lock (Lock) { //t ...