java中的线程(2):如何正确停止线程之2种常见停止方式
1.常见停止方式
- 结束run函数,run中含退出标志位。
- 使用interrupt()方法中断线程
- 使用stop方法暴力终止(已经弃用)
2.结束run
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.sleep( * );
} 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):如何正确停止线程之2种常见停止方式的更多相关文章
- java中的线程(2):如何正确停止线程之3种常见停止方式
1.常见停止方式 自定义线程,其中含退出标志位,在run中判断它. 使用interrupt()方法中断线程 使用stop方法暴力终止(已经弃用) 2.使用标志位 class TestThread ex ...
- Java中的线程
http://hi.baidu.com/ochzqvztdbabcir/item/ab9758f9cfab6a5ac9f337d4 相濡以沫 Java语法总结 - 线程 一 提到线程好像是件很麻烦很复 ...
- Java中的线程Thread总结
首先来看一张图,下面这张图很清晰的说明了线程的状态与Thread中的各个方法之间的关系,很经典的! 在Java中创建线程有两种方法:使用Thread类和使用Runnable接口. 要注意的是Threa ...
- 浅谈利用同步机制解决Java中的线程安全问题
我们知道大多数程序都不会是单线程程序,单线程程序的功能非常有限,我们假设一下所有的程序都是单线程程序,那么会带来怎样的结果呢?假如淘宝是单线程程序,一直都只能一个一个用户去访问,你要在网上买东西还得等 ...
- 第9章 Java中的线程池 第10章 Exector框架
与新建线程池相比线程池的优点 线程池的分类 ThreadPoolExector参数.执行过程.存储方式 阻塞队列 拒绝策略 10.1 Exector框架简介 10.1.1 Executor框架的两级调 ...
- Java多线程编程(1)--Java中的线程
一.程序.进程和线程 程序是一组指令的有序集合,也可以将其通俗地理解为若干行代码.它本身没有任何运行的含义,它只是一个静态的实体,它可能只是一个单纯的文本文件,也有可能是经过编译之后生成的可执行文 ...
- 浅析Java中的线程池
Java中的线程池 几乎所有需要异步或并发执行任务的程序都可以使用线程池,开发过程中合理使用线程池能够带来以下三个好处: 降低资源消耗 提高响应速度 提高线程的可管理性 1. 线程池的实现原理 当我们 ...
- Java中的线程到底有哪些安全策略
摘要:Java中的线程到底有哪些安全策略呢?本文就为你彻底分析下! 本文分享自华为云社区<[高并发]线程安全策略>,作者:冰 河 . 一.不可变对象 不可变对象需要满足的条件 (1)对象创 ...
- [译]线程生命周期-理解Java中的线程状态
线程生命周期-理解Java中的线程状态 在多线程编程环境下,理解线程生命周期和线程状态非常重要. 在上一篇教程中,我们已经学习了如何创建java线程:实现Runnable接口或者成为Thread的子类 ...
随机推荐
- System.Web.Mvc.JsonResult.cs
ylbtech-System.Web.Mvc.JsonResult.cs 1.程序集 System.Web.Mvc, Version=5.2.3.0, Culture=neutral, PublicK ...
- 利用R语言制作出漂亮的交互数据可视化
利用R语言制作出漂亮的交互数据可视化 利用R语言也可以制作出漂亮的交互数据可视化,下面和大家分享一些常用的交互可视化的R包. rCharts包 说起R语言的交互包,第一个想到的应该就是rCharts包 ...
- SVN 环境搭建
安装配置 安装环境 #查看系统版本环境 [root@svn ~]# cat /etc/redhat-release CentOS release 6.7 (Final) [root@svn ~]# u ...
- 各ui库项目结构
饿了么的ui组件库 sass build:webpack配置文件 examples: element api的页面文档 packages: 放置组件 css放在./theme-chalk 下 src ...
- Spring MVC(二)--Spring MVC登陆实例
本文通过一个简单的登陆实例实现Spring MVC的流程,同时整合 MyBatis使用,流程是这样的: 1.访问一个URL进入登陆界面 2.输入正确的用户名和密码,成功则进入index页面,否则留在登 ...
- 【DM8168学习笔记2】DM8168 EZSDK 结构
1 2 3 4 5
- spring boot 源码解析11-ConfigurationClassPostProcessor类加载解析
前言 ConfigurationClassPostProcessor实现了BeanDefinitionRegistryPostProcessor接口,该类会在AbstractApplicationCo ...
- express-generator简单使用
1.安装 npm install express npm install -g express-generator 全局安装.express-generator是一个node的自动化创建项目工具,类似 ...
- hbase 聚合操作
hbase本身提供了 聚合方法可以服务端聚合操作 hbase中的CoprocessorProtocol机制. CoprocessorProtocol的原理比较简单,近似于一个mapreduce框架.由 ...
- HBase底下的存储机制
Split机制:可以理解为HDFS上Block一分二的情况.每个Table一开始只有一个region,随着数据不断插入表,region不断增大,当增大到一个阀值的时候,Hregion就会等分会两个新的 ...